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WD33C93A SCSI Bus 
Interface Controller 


FEATURES 

• Implements full SCSI bus features: arbitration, 
disconnect, reconnect, parity generation/checking 
on both data ports, soft reset, and synchronous 
data transfers. 

• Asynchronous Data transfers up to 2.5 Mb/sec 

• Synchronous Data transfers up to 5.0 Mb/sec 

• Synchronous offset selectable from 1 to 12 bytes. 

• Compatible with most microprocessors through an 
8-bit data bus; supports both multiplexed and non- 
multiplexed address/data bus systems. Host bus 
data parity checking and generation is an optional 
feature. 

• Can be used as host adapter (SCSI Initiator) or 
peripheral adapter (SCSI Target). 

• Local host data transfer options include 
programmed I/O, single byte DMA, burst (multibyte) 
DMA, or direct bus access (WD bus) transfers. 

• Includes 48-ma drivers for direct connection to 
the SCSI bus. 

• 24 bit transfer counter. 

• Programmable timeout for selection and reselection. 

• Internal Microcontroller 

• “Combination” commands greatly reduce interrupt- 
handling responsibilities. 

• Special “Translate Address” command performs 
the Logical-to-Physical addressed translation. 

• Single +5V supply. 

• Available in 44-pin chip carrier or 40-pin DIP 

• Low power CMOS design. 

DESCRIPTION 

The WD33C93A is a MOS/VLSI device which is imple- 
mented in Western Digital’s CMOS process. It operates 
from a single 5 volt supply and is available in either a 44- 
pin chip carrier or a 40-pin dual-in-line package. All 
inputs and outputs are TTL-compatible. 


The WD33C93A is intended for use in systems which 
interface to the SCSI (Small Computer System Inter- 
face) Bus. The WD33C93A can operate in both the 
Initiator (typically, a host computer system) and the 
Target (typically, a peripheral device) SCSI bus roles. 

When used in the host system, the WD33C93A inter- 
faces to both the host bus and to the SCSI bus. To 
perform a SCSI operation, the host processor must 
issue a command to the WD33C93A to select the 
desired Target. The WD33C93A then arbitrates for the 
SCSI bus and selects the peripheral unit. If it fails to get 
the bus because of a higher priority bus device, it 
continues trying, notifying the host when it has suc- 
ceeded by generating an interrupt. At this point, the 
WD33C93A is operating in the initiator role. When the 
peripheral requests a SCSI command from the host, the 
WD33C93A receives the request and generates 
another interrupt to the host. The host responds to this 
interrupt by issuing a “Transfer Info” command and 
supplying SCSI command bytes to the WD33C93A. 
The WD33C93A transfers the SCSI command to the 
peripheral, and then waits for the next bus phase 
request. This process continues until all SCSI informa- 
tion including data, status, and messages have been 
transferred. 

The WD33C93A also offers high level Select-And- 
Transfer commands, which may be used to eliminate 
the interrupt-handling which is otherwise typically 
required between each SCSI bus phase. 

When the WD33C93A is used in a peripheral system, it 
interfaces with a local processor and the SCSI bus just 
as it does when used as a host adapter. In this environ- 
ment, the WD33C93A will operate primarily in a Target 
role. The Target-role command set enables the 
WD33C93A to request each SCSI bus phase individu- 
ally, or the special combination commands may be used 
for automatic SCSI bus phase sequencing. 

The WD33C93A has an internal microcontroller, a reg- 
ister task file, and SCSI interface logic. This architec- 
ture supports both tight control of the protocol for non- 
standard SCSI implementations, as well as a hands- 
free mode for standard SCSI applications. 
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4. PIN DESCRIPTIONS 

4.1 PROCESSOR/DMA INTERFACE 


DIP 

(40 PIN) 

PLCC 

(44 PIN) 

NAME 

I/O 

FUNCTION 

7 

8 

CLK 

1 

8-16 MHz square wave clock. 

36 

40 

MR 

1 

Reset is an active low input which forces the 
WD33C93A into an idle state. All SCSI signals are 
forced to the negated state. 

10 

12 

INTRQ 

0 

Interrupt Request to external microprocessor. 

Used to indicate command completion/termination 
or a need to service the SCSI interface. This bit is 
reset when the SCSI Status register is read. 

23 

26 

RE 

I/O 

Read enable is an active low input which is used 
with CS- to read a WD33C93A register. In WD Bus 
mode, it is used as an output to read data from a 
sector buffer. (Tri-State) 

22 

25 

WE 

I/O 

Write enable is an active low input which is used 
with CS- to write a WD33C93A register. In WD 

Bus mode, it is used as an output to write data to 
a sector buffer. (Tri-State) 

21 

24 

CS 

1 

Chip Select is an active low input which is used to 
qualify RE- and WE- when accessing a register. 

This signal must be inactive during a DMA cycle 
(DACK- active in DMA/burst mode, or DRQ active 
in WD Bus mode). 

19 

21 

AO 

1 

Address pin used to access the internal registers 
for non-multiplexed address/data busses (i.e., the 
ALE pin is grounded). The address of the desired 
register is loaded into the Address register during 
a write cycle with A0 = 0. The selected register is 
then accessed when AO = 1 . 

24 

27 

ALE 

1 

Address Latch Enable is used for multiplexed 
address/data busses to load the address of the 
desired WD33C93A register from the data bus. 

If indirect addressing is to be used, the ALE pin 
should be grounded. See the description of the 
Address register for a complete discussion of 
direct and indirect addressing. 

9 

10 

DACK/(RCS) 

I/O 

DMA acknowledge input used for interfacing to an 
external DMA controller. When DACK 
is low, all bus transfers are to/from the Data regis- 
ter regardless of the contents of the ADDRESS 
register. In WD Bus mode, this pin functions as a 
RAM chip select output to allow the WD33C93A 
to access a sector buffer. RE- and WE- are outputs 
when RCS- is active. Since this pin can be 
an open drain output, a pullup resistor is required 
when operating in WD Bus mode. 

8 

9 

DRQ/ (DRQ) 

I/O 

Data request is an output when interfacing to an 
external DMA controller, and an input when in 

WD Bus mode. When used with an external DMA 
controller, DRQ- and DACK- form the handshake 
for the data-byte transfers. In Burst mode, DRQ- 
remains low as long as there is data to transfer. In 
WD Bus mode, the WD33C93A performs burst 
transfers while DRQ is high, and when DRQ is low, 
data transfers are inhibited, RCS- is false, and the 
RE- and WE- outputs are disabled. Since this pin 
can be an open drain output, a pullup resistor is 
required when operating in DMA or Burst mode. 

18-11 

17-13 

D7-D0 

I/O 

Host processor data bus. 


11 

DP 

I/O 

Data Parity, used only for checking/generating 
host data bus parity during data transfers, (odd) 
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4.2 SCSI INTERFACE 

Note: All pins have open-drain output drivers. 


DIP 

(40 PIN) 

PLCC 

(44 PIN) 

NAME 

I/O 

FUNCTION 

39 

43 

REQ 

I/O 

REQ- is an input in the initiator role and an output 
in the target role. It indicates a request for a REQ/ 
ACK data transfer. 

38 

42 

ACK 

I/O 

ACK- is an output in the initiator role and an input 
in the target role. It is used to indicate an 
acknowledgement for a REQ/ACK data transfer 
handshake. 

37 

41 

AfN 

I/O 

ATN- is an output in the initiator role and an input 
in the target role. It is used to indicate the SCSI 
Attention condition. 

2 

3 

MSG 

I/O 

MSG- is an input in the initiator role and an output 
in the target role. It is asserted during a Message 
phase. 

4 

5 

C/D 

I/O 

C/D- is an input in the initiator role and an output in 
the target role. It is used to indicate whether 

Control or Data information is on the SCSI data 
bus. 

1 

2 

I/O 

I/O 

I/O- is an input in the initiator role and an output in 
the target role. It controls the direction of data 
movement on the SCSI data bus with respect to an 
Initiator. 

5 

6 

BSY 

I/O 

BSY- is asserted when the WD33C93A is 
attempting to arbitrate for the SCSI bus or when 
connected as a Target. 

6 

7 

SEL 

I/O 

SEL- is asserted when the WD33C93A is 
attempting to select or reselect another SCSI 
device. 

N/A 

28 

SDP 

I/O 

SCSI data bus parity signal, (odd) 

34-26 

38-29 

SD7-SD0 

I/O 

SCSI data bus. 


29-4 


12 - 12-90 




WD33C93A 


5 WD33C93A BLOCK DIAGRAM 
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6. WD33C93A REGISTERS 


6.1 REGISTER MAP 


AO 

R/W 

REGISTER ACCESSED 

ADDRESS 

(Hex) 

0 

R 

AUXILIARY STATUS 



XX 

0 

W 

ADDRESS REGISTER 



XX 

1 

R/W 

OWN ID REGISTER 


/CDB SIZE 

00 

1 

R/W 

CONTROL REGISTER 



01 

1 

R/W 

TIMEOUT PERIOD REGISTER 



02 

1 

R/W 

TOTAL SECTORS REGISTER 


/CDB 1ST 

03 

1 

R/W 

TOTAL HEADS REGISTER 


/CDB 2ND 

04 

1 

R/W 

TOTAL CYLINDERS REGISTER (MSB) 


/CDB 3RD 

05 

1 

R/W 

TOTAL CYLINDERS REGISTER (LSB) 


/CDB 4TH 

06 

1 

R/W 

LOGICAL ADDRESS (MSB) 


/CDB 5TH 

07 

1 

R/W 

LOGICAL ADDRESS (2ND) 


/CDB 6TH 

08 

1 

R/W 

LOGICAL ADDRESS (3RD) 


/CDB 7TH 

09 

1 

R/W 

LOGICAL ADDRESS (LSB) 


/CDB 8TH 

0A 

1 

R/W 

SECTOR NUMBER REGISTER 


/CDB 9TH 

0B 

1 

R/W 

HEAD NUMBER REGISTER 


/CDB 10TH 

OC 

1 

R/W 

CYLINDER NUMBER REGISTER (MSB) 


/CDB 11TH 

0D 

1 

R/W 

CYLINDER NUMBER REGISTER (LSB) 


/CDB 12TH 

0E 

1 

R/W 

TARGET LUN REGISTER 



OF 

1 

R/W 

COMMAND PHASE REGISTER 



10 

1 

R/W 

SYNCHRONOUS TRANSFER REGISTER 



11 

1 

R/W 

TRANSFER COUNT REGISTER (MSB) 



12 

1 

R/W 

TRANSFER COUNT REGISTER (2ND BYTE) 


13 

1 

R/W 

TRANSFER COUNT REGISTER (LSB) 



14 

1 

R/W 

DESTINATION ID REGISTER 



15 

1 

R/W 

SOURCE ID REGISTER 



16 

1 

R 

SCSI STATUS 



17 

1 

R/W 

COMMAND REGISTER 



18 

1 

R/W 

DATA REGISTER 



19 

1 

R 

AUXILIARY STATUS 

(DIRECT ADDRESSING MODE) 

IF 


NOTES: 


1. All unused bits of a defined register are reserved and must be zero. 

2. Reading an undefined or unavailable register results in an all-ones data bus output. 

3. Register addresses are determined by the Address register bits ARO thru AR7. 

4. When using a multiplexed address/data bus with ALE, the AO pin is ignored and the Address 
register is loaded with ALE. In this mode, the Auxiliary Status register is mapped at Hex IF. 

5. See section 6.3 for a description of how reset affects the internal registers. 
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6.2 REGISTER DESCRIPTIONS 
6.2.1 AUXILIARY STATUS REGISTER 
(Address Hex IF) 

The Auxiliary Status register is a read-only register 
which contains general status information not directly 
associated with the interrupt condition. The Auxiliary 
Status register may be accessed at any time, except 
during DMA accesses (DACK- asserted in DMA/Burst 
mode, or DRQ asserted in WD bus mode). 


7 

6 

5 

4 

3 

2 

1 

0 

INT 

LCI 

BSY 

CIP 

0 

0 

PE 

DBR 


Bit 0 DBR Data Buffer Ready is used during pro- 
grammed I/O to indicate to the pro- 
cessor whether or not the Data register 
is available for reading or writing. Dur- 
ing Send or Transfer commands which 
transmit data over the SCSI bus, the 
DBR bit is set when the WD33C93A is 
ready to take a byte from the host; the 
bit is reset when the processor writes 
the byte to the DATA register. During 
Receive or Transfer commands which 
receive data over the SCSI bus, the 
DBR is set when a byte is received; it is 
reset when the processor reads the 
byte from the DATA register. 

Bit 1 PE Parity Error status indicates that even 
parity was detected on a data byte 
received during an information trans- 
fer. Parity is checked on data received 
from the host bus during transfers out 
to the SCSI bus, and is checked on 
data received from the SCSI bus dur- 
ing transfers out to the host bus. 
Detection of a parity error will set the 
PE status bit regardless of the state of 
the HHP or HSP bits in the Control 
register. The PE bit is cleared when a 
new command is issued. 

Bit 2 Not used, will be zero. 


Bit 3 
Bit 4 


Bit 5 


Bit 6 


Bit 7 


Not used, will be zero. 

CIP COMMAND IN PROGRESS, when 
set, indicates that the WD33C93A is 
interpreting the last command entered 
into the Command register and there- 
fore this register is unavailable. When 
this bit is reset, a command may be 
written to the Command register. 

BSY BUSY indicates that a Level II com- 
mand is currently executing and there- 
fore only the Command register (when 
CIP - 0), the DATA register, and the 
Auxiliary Status register are access- 
ible by the host. A Level II command 
may not be written to the Command 
register when this bit is one. 

LCI LAST COMMAND IGNORED indi- 
cates that a command was issued by 
the host just prior to or concurrent with 
a pending interrupt, and therefore the 
command will be ignored and this sta- 
tus set. 

INT INTERRUPT PENDING indicates that 
the Intrq pin is asserted. The host 
should read the SCSI Status register 
to clear Intrq prior to issuing any 
commands. 
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6.2.2 ADDRESS REGISTER 
[Address XX Hex] 

The Address register is a write-only register which 
contains the address of the register to be accessed. 
Registers in the WD33C93A may be accessed in one of 
two ways: 

• Direct addressing (multiplexed address/data busses). 
In direct addressing, the falling edge of the ALE signal 
is used to latch the address into the ADDRESS regis- 
ter. The ALE is typically then followed by the CS- and 
WE- or RE- signals that access the selected register. 
Also, in direct addressing, the AUXILIARY STATUS 
register is located at address IF Hex. 

• Indirect addressing (separate address/data busses). 
In indirect addressing, the register access is per- 
formed in two separate cycles. This method is 
enabled by attaching ALE to ground. First, the 
Address register is loaded by performing a write of the 
desired address to the WD33C93A (WE- and CS- 
asserted) with A0 = 0. Then the register is accessed 
by asserting CS- and WE- or RE-, with A0 = 1. Also, 
following every access with AO = 1 , the Address regis- 
ter will automatically increment to point at the next 
register, with the exception of the following locations: 
Auxiliary Status register, Data register, and the Com- 
mand register. In indirect addressing, the Auxiliary 
Status register is accessed by performing a read (CS- 
and RE- asserted) with A0 = 0. 

OWN ID/CDB SIZE REGISTER 


6.2.3 OWN ID/CDB SIZE REGISTER 
[Address 00 Hex] 

The Own ID/CDB Size register, in its first mode, con- 
tains both the encoded ID of the WD33C93A on the 
SCSI bus and several control bits that are used to 
initially configure the device during the “Reset” com- 
mand. These bits control ‘advanced feature’ selection, 
host bus parity enable, and selection of the input clock 
division. In its second mode (when advanced features 
are enabled, see 7.3), this register is used during the 
combination commands to specify the SCSI CDB size if 
the command group is unknown to the WD33C93A. 

In the first mode, this register (as defined below) is 
sampled and becomes effective only after a “Reset” 
command is issued to the device. This register must be 
initialized, and then a “Reset” command issued, to set 
the SCSI bus ID, the clock divisor, and the operating 
modes before any other commands are issued. 

In the second mode, bits 3-0 of this register are used 
during the Select-and-Transfer and Wait-for-Select 
commands to specify the SCSI Command Descriptor 
Block size if it is not a group 0, group 1, or group 5 
command. This mode is enabled only when advanced 
features are enabled (see 7.3). 


7 

6 

5 

4 

3 

2 

1 

0 

FS1 

FS0 

0 

EHP 

EAF 

ID2 

ID1 

IDO 


Bit 0-2 IDn SCSI ID Bits 0-2 set the SCSI bus ID 
number that the WD33C93A will use 
during arbitration and selection. 

Bit 3 EAF ENABLE ADVANCED FEATURES, 
when set to one, causes the 
WD33C93 A to enable certain 
advanced features (see section 7.3). 
When this bit is zero, those features 
are disabled. 

Bit 4 EHP ENABLE HOST PARITY, when set to 
one, enables odd parity checking on 
the host bus; the PE bit in the Auxiliary 


Status register will indicate parity 
errors detected on the host bus, and 
the HHP bit in the Control register will 
be used. When this bit is zero, no 
checking is performed on the host bus; 
the PE bit is not set when a parity error 
is detected on the host bus, and the 
HHP bit must be set to zero. 

NOTE: Parity is always generated on 
the host data parity bit (DP), regard- 
less of the state of this bit. 

Bit 5 Not used, will be zero. 
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Bit 6-7 FSn FREQUENCY SELECT 0-1 select the 
divisor that is applied to the input 
clock. The resulting clock is used for 
data transfer timing and for SCSI bus 
arbitration timing. The table below 


shows input clock frequency ranges 
and the corresponding divisors. The 
correct divisor for the input clock must 
be used, or SCSI bus timing specifica- 
tions may not be met. 


INPUT CLOCK 
FREQUENCY 
(MHZ) 

FS1 

FS0 

RESULTING 

DIVISOR 

8-10 

0 

0 

2 

12-15 

0 

1 

3 

16 

1 

0 

4 

XX 

1 

1 

undefined 


Note that an 11 MHZ clock rate should not be used, as the resulting SCSI bus clear delay may violate SCSI 
specifications. The formula for computing the maximum SCSI data transfer rate is: 

MAXIMUM SCSI TRANSFER RATE = INPUT CLOCK FREQUENCY [MByte/sec ] 

CLOCK DIVISOR 


29 


6.2.4 CONTROL REGISTER 
[Address 01 Hex] 

The CONTROL register is used to enable/disable cer- 
tain functions, such as response to parity errors and the 
SCSI attention condition, interrupt handling, and data 
transfer modes. 


7 

6 

5 

4 

3 

2 

1 

0 

DM2 

DM1 

DM0 

HHP 

EDI 

IDI 

HA 

HSP 


BitO HSP The HALT on SCSI PARITY ERROR 
bit enables the WD33C93A to termi- 
nate a Receive or Transfer command if 
a parity error is detected on an incom- 
ing SCSI data byte. In the Initiator role, 
termination due to a SCSI parity error 
causes the ACK- pin to be left in the 
active state in order to inhibit any addi- 
tional data transfers (REQs) by the 
Target; this facilitates error handling 
with the Target. Synchronous data 
transfers check parity every 4096 
bytes, or at the end of the remaining 
transfer count, whichever is less. 
Asynchronous transfers check parity 
on every byte. 


Bit 1 HA The HALT on ATTENTION bit (in Tar- 
get mode only) enables the 
WD33C93A to terminate a Send or 
Receive command if the ATN- input is 
asserted. This normally indicates that 
the Initiator detected a parity error 
while receiving data from the 
WD33C93A. The ATN- input is tested 
before the start of a data transfer, 
every 4096 bytes if the transfer count 
is greater than 4096, and after the end 
of the transfer. These ules apply to 
both synchronous and asynchronous 
transfers. 
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Bit 2 IDI The Intermediate Disconnect Interrupt 
bit, when set, enables the WD33C93A 
to generate an 85H disconnect inter- 
rupt and suspends a Select-and- 
Transfer command if the Target dis- 
connects according to the defined 
SCSI protocol. When this bit is reset, 
no interrupt is generated by a valid 
disconnect. This feature, when used 
with the Resume SAT command, 
provides support for overlapped SCSI 
operations. IDI is also used to select 
execution options in Target mode com- 
bination commands that serve to 
reduce host system overhead. Refer to 
Section 7 for more details. 

Bit 3 EDI When the Ending Disconnect Interrupt 
bit is set, the 16H interrupt which nor- 
mally follows the Command Complete 
message during the execution of a 
Select-And-Transfer command will be 
suppressed until the Target discon- 
nects from the SCSI bus. EDI is also 
used in the Target mode combination 
commands to enable chaining 


between those commands, resulting in 
reduced host system overhead. Refer 
to Section 7 for more details. 

Bit 4 HHP The Halt on Host Parity Error bit 
enables the WD33C93A to imme- 
diately terminate a Send or Transfer 
command if a parity error is detected 
on an incoming host data byte. Host 
parity errors are checked according to 
the rules for checking SCSI parity 
errors. However, a halt on a host parity 
error will not hold the ACK- signal 
asserted when an error occurs. Host 
parity checking is performed at the 
same intervals as SCSI parity 
checking. 

Bit 5-7 DMx DMA Mode Select bits 2-0 are used to 
select the DMA mode of operation, 
which describes the host bus transfer 
mode used during Data In or Data Out 
phases. The following table describes 
the different DMA modes, and the 
state of these bits to select them: 


DM2 

DM1 

DM0 

DMA MODE SELECTED 

0 

0 

0 

Polled I/O Mode, or no DMA enabled. All data phase transfers are 
performed by polling for DBR in the Auxiliary Status register, and then 
writing (reading) the data to (from) the Data register. 

0 

0 

1 

Burst Mode selects a demand-mode DMA interface. In this mode, the 

DRQ- signal will be active as long as there is data/space in the internal 

FIFO to allow the transfer to continue. The DMA controller responds by 
asserting DACK- and RE-/WE- as long as DRQ- is active. 

0 

1 

0 

WD Bus Mode should be selected when the WD33C93A is connected to a 
WD Bus. This mode is also referred to as Direct Buffer Access (DBA) 
mode. 

In this mode, the WD33C93A acts as a bus master, and all data access 
signals reverse their direction: The DRQ- signal become the DRQ input, 
which enables the WD33C93A to drive the buffer bus control signals. 

The DACK- signal becomes the RCS- output, which is asserted as a chip 
select for the buffer. RE- and WE- become outputs which drive the read 
and write functions of the external FIFO/RAM buffer. As long as the DRQ 
signal is asserted, transfers will continue in a burst manner, until the 
transfer is complete or the host/local up decides to pause the transfer by 
negating the DRQ signal; after negating DRQ, one more transfer may 
occur before the RCS-, RE-, and WE- signals are negated. 

1 

0 

0 

DMA Mode is selected when the WD33C93A is to be used with a DMA 
controller in single-type transfer mode. In this mode, DRQ- is asserted 
and then negated, and the DMA controller responds by asserting DACK- 
and WE- or RE-, for each data byte transferred to/from the WD33C93A. 
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6.2.5 TIMEOUT PERIOD REGISTER 
[Address 02 Hex] 


The Timeout Period register is an 8-bit register contain- 
ing a preset value which determines the timeout period 
for Select and Reselect commands. This value may be 
calculated as a function of the input clock frequency and 
the desired timeout period, as shown in the following 
equation: 


register value 


Tper * Ficlk 
80d 


Where: 


Tper = the desired timeout period in milliseconds: 
Ficlk = the input clock frequency at the CLK pin in 
Megahertz (with no divisor applied), 
d = decimal 


The constant ‘80’ scales the units of the equation, as is 
based on the internal timeout cycle time. The user 
should round the resulting ‘register value’ up to the next 
integral value to ensure that the user’s minimum timeout 
requirement is met. 

The timeout period specifies how long the WD33C93A 
will wait for a response (indicated by assertion of the 
BSY- signal) after it has begun the selection phase 
(assert SEL- and negate BSY-) before terminating the 
command. The timeout function can be disabled by 
loading the Timeout Period register with zero. 

NOTE: The following twelve registers are used 
exclusively by the Translate Address and/or “com- 
bination” commands. The function of each register 
is determined by the type of command issued. 


6.2.6 TOTAL SECTORS REGISTER/ 

CDB 1ST BYTE [Address 03 Hex] 

Translate Address: The Total Sectors register should 
be set to the total number of sectors per track prior to 
issuing a Translate Address command. 

Select-and-Transfer: This register should be loaded 
with the first byte of the Command Descriptor Block 
before issuing a Select-And-Transfer command. 

Wait-For-Select-And-Receive: The WD33C93A will 
store the first byte of the received CDB in this register. 

6.2.7 TOTAL HEADS REGISTER/ 

CDB 2ND BYTE [Address 04 Hex] 

Translate Address: This register holds the total number 
of heads during a Translate Address command. 

Select-And-Transfer: This register should be loaded 
with the second byte of the CDB before issuing a Select- 
And-Transfer command. 

Wait-For-Select-And-Receive: The WD33C93A will 
store the second byte of the received CDB in this 
register. 


6.2.8 TOTAL CYLINDERS REGISTER/ 

CDB 3RD AND 4TH BYTES 
[Address 05, 06 Hex] 

Translate Address: This is a 16-bit register which holds 
the total number of cylinders. 


Select-And-Transfer: This register should be loaded 
with the third and fourth bytes of the CDB before issuing 
a Select-And-Transfer command. 

Wait-For-Select-And-Receive: The WD33C93A will 
store the third and fourth bytes of the received CDB in 
this register. 

6.2.9 LOGICAL ADDRESS REGISTER/ 

CDB 5TH-8TH BYTES [Address 07, 

08, 09, 0A Hex] 

Translate Address: The Logical Address register is a 
32-bit register which should be loaded with the logical 
address to be translated prior to issuing the Translate 
Address command. 

Select-And-Transfer: For six byte CDBs, only the first 
two bytes of this register are loaded with the fifth and 
sixth bytes of the CDB. For ten and twelve byte CDBs, 
this register is loaded with the fifth, sixth, seventh, and 
eighth bytes of the CDB. 

Wait-For-Select-And-Receive: The WD33C93A will 
store the fifth, sixth, seventh (if any), and eighth (if any) 
bytes of the received CDB in this register. 
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6.2.10 SECTOR NUMBER 
REGISTER/CDB 9TH BYTE [Address 0B Hex] 

Translate Address: This register will contain the result- 
ing sector number following a Translate Address 
command. 

Select-And-Transfer: This register should be loaded 
with the ninth byte of a ten or twelve byte CDB before 
issuing a Select-and-Transfer command. 

Wait-For-Select-And-Receive: The WD33C93A will 
store the ninth byte of a ten or twelve byte received CDB 
in this register. 

6.2.11 HEAD NUMBER REGISTER 
CDB 10TH BYTE [Address 0C Hex] 

Translate Address: The Head Number register con- 
tains the resulting head number following a Translate 
Address command. If automatic compensation for 
spare sectors on a disk is to be performed by the 
WD33C93A, then the number of spare sectors per 
cylinder must be written into this register before issuing 
the Translate Address command. It should be noted that 
when compensation is used, the maximum number of 
cylinders allowed is 4096, and the maximum number of 
heads is 15. An initial value of zero in this register 
indicates that no compensation is to be performed. 
Select-And-Transfer: This register should be loaded 
with the tenth byte of a ten or twelve byte CDB before 
issuing a Select-And-Transfer command. 

Wait-For-Select-And-Receive: The WD33C93A will 
store the tenth byte of a ten or twelve byte received CDB 
in this register. 

6.2.12 CYLINDER NUMBER REGISTER/CDB 
11TH AND 12TH BYTES [Address 0D, 0E, Hex] 

Translate Address: The Cylinder Number register is a 
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16-bit register which contains the resulting cylinder 
number following execution of the Translate Address 
command. When a Translate Address command involv- 
ing automatic compensation for spare sectors is issued 
(i.e. the Head Number register initially contains a non- 
zero value), then this register must be loaded with total 
number of sectors per cylinder (total sectors/track * 
total heads — total spare sectors/cyl) before issuing the 
command. 

Select-And-Transfer: This register should be loaded 
with the eleventh and twelfth bytes of a twelve byte CDB 
before issuing a Select-and-Transfer command. 

Wait-For-Select-And-Receive: The WD33C93A will 
store the eleventh and twelfth bytes of a twelve byte 
received CDB in this register. 

Send-Status-And-Command-Complete: The CDB11 
register is used to specify the returned status byte to be 
sent during a Send-Status-And-Command-Complete 
command. The CDB12 register is used to determine the 
type of Command-Complete message sent by the 
WD33C93A. If bit 0 of the CDB12 register is set to one, 
then a linked Command Complete message will be sent 
during command execution. In this case, bit 1 of the 
CDB12 register is used as a FLAG bit to determine 
whether a OA Hex (FLAG = 0) or a OB Hex (FLAG = 1) 
Linked Command Complete message is sent. If bit 0 is 
zero, then a simple Command Complete message (00 
Hex) is sent. 

6.2.13 TARGET LUN REGISTER 
[Address OF Hex] 

The Target LUN register is used to hold both the Logical 
Unit Number (LUN) and Target status information dur- 
ing various WD33C93A commands and sequences. 
During a Select-And-Transfer or Reseiect-And-Transfer 
command, the contents of this register (along with the 
Source ID register) are used to generate and check the 
Identify messages which are transferred across the 
SCSI bus. In addition, the Target LUN register is used to 
hold the Target Status byte received during a Select- 
And-Transfer command. 


During Wait-For-Select-And-Receive commands, this 
register may hold the image of the Identify message 
received from the Initiator. If the TLV bit is zero, there 
was no Identify message received. If the TLV bit is one, 
then a valid Identify message was received. The DOK 
bit will then indicate whether or not the Initiator has 
enabled disconnects. 

During Reselect-And-Transfer commands, this register 
is used to set the LUN to be used in the Identify mes- 
sage sent to the Initiator after Selection phase. The TLV 
and DOK bits are not used. 

In advanced mode, during Select-And-Transfer com- 
mands, this register is used to handle reselection by an 
unexpected Target. In this mode, this register will hold 
the image of the Identify message received from the 
Target. In this case, the TLV bit is one, since the Target 
always sends the Identify message. 

6.2.14 COMMAND PHASE REGISTER 
[Address 10 Hex] 

The Command Phase register is used during combina- 
tion commands to indicate which phases of these multi- 
phase commands have been completed. Thus, if the 
command has terminated abnormally, the processor 
can read this register to determine the cause of the 
termination and how to respond to it. This register is 
also used to resume combination commands by loading 
this register with a value that indicates the next desired 
or expected bus phase, and reissuing the command. 
Refer to the description of the specific commands for 
details regarding the various command phases and 
resume values. 
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6.2.15 SYNCHRONOUS TRANSFER 
REGISTER [Address 11 Hex] 

The Synchronous Transfer register is used to select 
between synchronous and asynchronous transfers, 
and is also used to define the maximum transfer rate. 
For information phases other than a “data” transfer 
phase, or when the selected offset is zero 
(OF3-OFO = 0), asynchronous transfers will occur. 
Values greater than zero define a synchronous transfer 
mode and the offset is determined as shown below. This 
offset determines the effective FIFO depth for syn- 


chronous data transfers, and is typically determined by 
negotiation with the other SCSI device (as defined in 
the SCSI standard). The Transfer Period control bits 
select the minimum transfer period for both syn- 
chronous and asynchronous SCSI transfers and, if WD- 
Bus mode is used, the transfer period and the width of 
the RE-/WE- strobes for host transfers. The period is 
defined in terms of the internal clock cycle time; the 
frequency of this clock is determined by the divisor 
selected in the OWN ID register. 
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Bit 0-3 OFx The OFFSET bits are used to select the desired offset according to the following: 


OF3 

OF2 

OF1 

OFO 

SELECTED OFFSET 

0 

0 

0 

0 

Note 1 

0 

0 

0 

1 

1 

0 

0 

1 

0 

2 

0 

0 

1 

1 

3 

0 

1 

0 

0 

4 

0 

1 

0 

0 

5 

0 

1 

1 

0 

6 

0 

1 

1 

1 

7 

1 

0 

0 

0 

8 

1 

0 

0 

1 

9 

1 

0 

1 

0 

10 

1 

0 

1 

1 

11 

1 

1 

0 

0 

12 

1 

1 

0 

1 

12 

1 

1 

1 

X 

12 


Note 1* — Asynchronous data phase transfers 
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Bit 4-6 TPx The TRANSFER PERIOD bits are used to select the desired transfer period according to the 
following table: 


TP2 

TP1 

TPO 

SCSI/WD-BUS 

TRANSFER PERIOD 

(SCSI REQ/ACK synchronous pulse width 
and WD-BUS RE-/WE- pulse width) 

0 

0 

X 

8 cycles 

(4 cycles) 

0 

1 

0 

2 cycles 

(1 cycle) 

0 

1 

1 

3 cycles 

(1 cycle) 

1 

0 

0 

4 cycles 

(2 cycles) 

1 

0 

1 

5 cycles 

(3 cycles) 

1 

1 

0 

6 cycles 

(4 cycles) 

1 

1 

1 

7 cycles 

(4 cycles) 


The ‘cycle’ referred to above is the period of the internal data transfer clock after the divisor chosen in the OWN ID 
register is applied. This period is calculated by the following formula: 


DIVISOR (from OWN ID) 

2 * INPUT CLOCK FREQUENCY (MHZ) 


6.2.16 TRANSFER COUNT REGISTER 
[Address 12, 13, 14 Hex] 

The Transfer Count register is a 24-bit register contain- 
ing a preset value for the internal transfer counter. This 
preset value is loaded into the internal transfer counter 
when a Send, Receive, or Transfer command is issued. 
This counter is used to define command completion by 
decrementing as each data byte is transferred over the 
SCSI bus and causing a successful completion inter- 
rupt when the counter reaches zero. In combination 
commands, this register specifies the number of bytes 
to be transferred during a Data phase. 

The counter function can be disabled by loading the 
Transfer Count register with zeroes prior to issuing a 
command or by setting the Single-Byte Transfer bit in 
the Command register concurrent with issuing the com- 
mand. If the counter is disabled, the Send, Receive, or 


Transfer command will be completed when a single byte 
has been transferred. 

After the completion of any successful transfer, the 
Transfer Count register will be zero. This includes com- 
mands issued in Single Byte Transfer mode. 

When a transfer is interrupted by a halt on error condi- 
tion, a SCSI bus phase change, or an abort, the Transfer 
Count register will contain the number of bytes NOT 
successfully transferred to/from the SCSI bus, includ- 
ing clearing the internal FIFO of any bytes left in the 
FIFO (see DATA register). This FIFO clearing process 
may cause the Transfer Count register to differ with the 
user’s DMA controller count, because some bytes may 
have been transferred into the FIFO, but not to the SCSI 
bus; therefore, the Transfer Count should be used to 
determine the actual number of bytes transferred to/ 
from the SCSI bus. 
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6.2.17 DESTINATION ID REGISTER 
[Address 15 Hex] 

The Destination ID register contains the encoded SCSI 
bus ID of the device which is to be selected or 
reselected when a Reselect or Select command is 
issued. This register also contains control bits that 
affect the operation of certain combination commands. 
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Bit 0-2 Destination ID bits DI0-DI2 contains 

the encoded SCSI bus ID of the device 
which is to be selected or reselected 
when a Reselect or a Select command 
is issued. 


Bit 6 


Bit 7 


DPD DATA PHASE DIRECTION, when 
advanced features are enabled (see 
7.3), is used to specify the expected 
direction of the SCSI data phase. This 
allows the WD33C93A to verify the 
direction during Select-And-Transfer 
commands before beginning the 
transfer. When this bit is zero, the 
expected direction is out (to the Tar- 
get). When this bit is one, the expected 
direction is in (from the Target). An 
unexpected information phase error 
will occur if the direction does not 
match the setting of this bit. 


SCC SELECT COMMAND CHAIN is used 
only when the Reselect-And-Transfer 
command is issued with EDI = 1. This 
bit selects which command is chained 
to when the data transfer is completed. 
When this bit is zero, a Send-Status- 
and-Command-Complete command 
begins executing. When this bit is one, 
a Send-Disconnect-Message com- 
mand begins executing. 
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6.2.18 SOURCE ID REGISTER 
[Address 16 Hex] 

The SOURCE ID register is used to report the SCSI bus 
ID of the device that has selected or reselected the 
WD33C93A. It also contains bits that enable and con- 
trol response to selection and reselection. 
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Bit 0-2 Six Source ID Bits 2-0 are valid only if the 
SIV bit is set to one. These bits indicate 
the SCSI bus ID of the device that 
selected or reselected the 
WD33C93A. 

Bit 3 SIV Source ID Valid is set to one after the 
WD33C93A is selected or reselected if 
the other SCSI bus device asserted its 
own bus ID bit (in addition to the bus ID 
bit of the WD33C93A) during the 
select/reselect phase. This bit is zero if 
only the bus ID bit of the WD33C93A 
was asserted. 


Bit 4 


Not used, will be zero. 


Bit 5 DSP Disable Select Parity, when set to one, 


causes the WD33C93A to ignore the 
bus parity when responding to selec- 
tion or reselection. When this bit is 
zero, any selection or reselection with 
a parity error is ignored. 

Bit 6 ES Enable Selection, when set to one, 
enables the WD33C93A to respond to 
a selection by another device on the 
SCSI bus. When this bit is zero, any 
selection is ignored. 

Bit 7 ER Enable Reselection, when set to one, 
enables the WD33C93A to respond to 
a reselection by another device on the 
SCSI bus. When this bit is zero, any 
reselection is ignored. 
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6.2.19 SCSI STATUS REGISTER 
[Address 17 Hex] 

The SCSI Status register is a read-only register which 
indicates the cause of the most recent interrupt request 
assertion. Interrupt request is asserted whenever a 
condition occurs within the WD33C93A that requires 
intervention by the host; for example: 

• the WD33C93A has been reset; 

• the command completed successfully; 

• the bus phase changed; 

• an error occurred. 

Once interrupt request has been asserted, the contents 
of this register will not change until after the SCSI 
STATUS register has been read or until the WD33C93A 
has been reset. 


BIT 7 
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SS7 

SS6 
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SS4 

SS3 

SS2 

SSI 

sso 


Bit 0-3 SSx SCSI Status bits 0-3 are status 
qualifiers whose meaning depends 
upon which upper (4-7) status bit is 
set. 

Bit 4-7 SSx SCSI Status bits 4-7 define the type of 
interrupt that occurred. The possible 
codes are defined in the following 
table: 


STATUS 

CODE 

GROUP MEANING 

0000 

xxxx 

The WD33C93A is in a reset state. 

0001 

xxxx 

A WD33C93A command has completed successfully. 

0010 

xxxx 

A WD33C93A command has paused or was aborted by 
an Abort command. 

0100 

xxxx 

A WD33C93A command has been terminated prematurely 
due to an error or other unexpected condition. 

1000 

xxxx 

An event on the SCSI bus requires service. 
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All other Status Code groups are currently not used and 
are reserved for future use. 

In the following tables, the ‘State’ cofumn indicates the 
current state from which the Status Code can occur. 
Also, the MCI field refers to the signals that define a 
SCSI bus information transfer phase: MSG, C/D, and 
I/O. A bit set to one indicates that the signal is asserted 
on the SCSI bus. A zero indicates negation. Whenever 
one of these Status Codes occurs, the REQ signal is 
asserted on the SCSI bus. The table below summarizes 
the meaning of the MCI field: 


MCI CODE 

MEANING 

000 

Data Out phase 

001 

Data In phase 

010 

Command phase 

011 

Status phase 

100 

Unspecified Info Out phase 

101 

Unspecified Info In phase 

110 

Message Out phase 

111 

Message In phase 


RESET STATE INTERRUPTS 


STATUS 

CODE 

STATE* 

SPECIFIC MEANING 

0000 

0000 

D, T, 1 

WD33C93 Reset. The device has been reset, or a Reset 
command has executed successfully with no advanced features 
enabled. The new state of the WD33C93A is disconnected. 

0000 

0001 

D, T, 1 

WD33C93A Reset. The device has successfully completed a 
Reset command with advanced features enabled. The new state 
of the WD33C93A is disconnected. 


* D = Disconnected 
T = Connected as a Target 
I = Connected as an Initiator 
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SUCCESSFUL COMPLETION INTERRUPTS 


STATUS 

CODE 

STATE* 

SPECIFIC MEANING 

0001 

0000 

D 

A Reselect command completed successfully. The new state of 
the WD33C93A is connected as a Target. 

0001 

0001 

D 

A Select command completed successfully. The new state of the 
WD33C93A is connected as an Initiator. 

0001 

0010 


Reserved for future use. 

0001 

0011 

D, T 

A Receive, Send, Reselect- And-Transfer, Wait-For-Select-And- 
Receive, Send-Status-And-Command-Complete, or a Send- 
Disconnect-Message command completed successfully 
(ATN- is not asserted). 

0001 

0100 

D, T 

A Receive, Send, Reselect-And-Transfer, Wait-For-Select-And- 
Receive, Send-Status-And-Command-Complete, or a Send- 
Disconnect-Message command completed successfully 
(ATN- is asserted). 

0001 

0101 

D, T 

A Translate Address command completed successfully. 

0001 

0110 

D, 1 

A Select-And-Transfer command completed successfully. 

0001 

0111 


Reserved for future use. 

0001 

1 MCI 

1 

A Transfer (non-Message IN phase) command completed 
successfully. MCI defines the new information type (SCSI bus 
phase) being requested. 


PAUSED OR ABORTED INTERRUPTS 


STATUS 

CODE 

STATE* 

SPECIFIC MEANING 

0010 

0000 

1 

A Transfer Info (Message-In phase) command has paused with 
ACK- asserted. This allows the host to examine the message 
before accepting it. 

0010 

0001 

1 

A Save Data Pointers message was received during a Select- 
And-Transfer command. The host should save its current data 
buffer pointer. 

0010 

0010 

D 

A Select or Reselect command was aborted. 

0010 

0011 

T 

A Receive or Send command has halted by an error or was 
aborted (ATN- is not asserted). 

0010 

0100 

T 

A Receive or Send command has halted by an error or ATN- 
asserted, or was aborted (ATN- is asserted). 

0010 

0101 

D 

An Abort was issued while the WD33C93A was in the 
process of being selected or reselected. 

0010 

0110 


Reserved for future use. 

0010 

0111 

D 

The WD33G93A has been reselected during a Select-And- 
Transfer (with IDI = 0) by a Target that does not match the SCSI 
bus ID loaded into the Destination ID register; or the following 
Identify message did not match the LUN loaded into the Target 
LUN register. ACK- has been left asserted following the Identify 
message, and the bus ID and LUN of the reselecting Target 
are available in the Source ID and Target LUN registers. 

(Advanced Mode only) 

0010 

1 MCI 

1 

A Transfer command was aborted. MCI define the new 
information type (SCSI bus phase) being requested. 


* D = Disconnected 
T = Connected as a Target 
I = Connected as an Initiator 
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TERMINATED INTERRUPTS 


STATUS 

CODE 

STATE* 

SPECIFIC MEANING 

0100 

0000 

D, T, 1 

An invalid command was issued. 

0100 

0001 

1 

An unexpected disconnect (SCSI bus free) by the Target caused 
a command to terminate. The new state of the WD33C93A is 
disconnected. 

0100 

0010 

D 

A timeout occurred during a Select or Reselect command. The 
state of the WD33C93A is disconnected. 

0100 

0011 

T, 1 

A parity error caused a command to terminate (ATN- is not 
asserted). The transfer direction determines whether it is a SCSI 
or host parity error. 

0100 

0100 

T, 1 

A parity error caused a command to terminate (ATN- is 
asserted). The transfer direction determines whether it is a SCSI 
or host parity error. 

0100 

0101 

D, T 

The Logical Address exceeded the disk boundaries. 

0100 

0110 

D 

A Target whose SCSI bus device ID does not match the bus ID 
set in the Destination ID register has reselected the WD33C93A 
during a Select-And-Transfer command (with IDI = 0). This 
interrupt occurs when the WD33C93A is not in Advanced Mode. 
The new state of the WD33C93A is connected as an Initiator. 

0100 

0111 

1 

An incorrect status byte (i.e. the status byte has a parity error) 
was received during a Select-And-Transfer command. The Data 
Register can be read to observe the status byte in error. 

0100 

1MCI 

1 

An unexpected information phase was requested. MCI define 
the SCSI bus phase which is requested. This is typically caused 
by a phase change before the Transfer Count has reached zero, 
or an unexpected phase sequence occurred during a Select- 
And-Transfer command. 


* D = Disconnected 
T = Connected as a Target 
I = Connected as an Initiator 
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SERVICE REQUIRED INTERRUPTS 


STATUS 

CODE 

STATE* 

SPECIFIC MEANING 

1000 

0000 

D 

The WD33C93A has been reselected. The new state of the 
WD33C93A is connected as an Initiator. No Identify message 
transfer has yet occurred. 

1000 

0001 

D 

The WD33C93A has been reselected in Advanced Mode. 

The SCSI bus ID of the Target may be read from the Source ID 
register. The Identify message from the Target may be read from 
the Data register. The ACK- signal is left asserted. The new 
state of the WD33C93A is connected as an Initiator. 

1000 

0010 

D 

The WD33C93A has been selected (no ATN- assertion). 

The new state of the WD33C93A is connected as a Target. 

1000 

0011 

D 

The WD33C93A has been selected (ATN- was asserted). 

The new state of the WD33C93A is connected as a Target. 

1000 

0100 

T 

The ATN- signal has been asserted. 

1000 

0101 

1 

A disconnect has occurred. The new state of the*WD33C93A is 
disconnected. 

1000 

0110 


Reserved for future use. 

1000 

0111 

T 

The Wait-For-Select-And-Receive command has paused 
because the first byte of the incoming CDB is not a known 
command group. The Own ID register must be loaded with the 
CDB length, and the command resumed. The CDB1 register 
may be examined to determine the SCSI command group from 
the opcode. The new state of the WD33C93A is connected as a 
Target. (Advanced Mode only) 

1000 

1 MCI 

1 

The REQ signal has been asserted following connection or 
when the WD33C93A is in the Initiator state and no command is 
executing. The information phase type should be examined. 

MCI define the information phase (SCSI bus phase) which is 
being requested. 


* D = Disconnected 
T = Connected as a Target 
I = Connected as an Initiator 
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6.2.20 COMMAND REGISTER 
[Address 18 Hex] 

The Command register is used to issue the WD33C93A 
commands. Since the WD33C93A expects the SCSI 
Status to have been read before the host can issue a 
valid command, a command should not be loaded into 
the Command register within seven microseconds 
(independent of input clock frequency) from the last 
SCSI Status read to avoid the command being ignored 
(indicated by the LCI bit in the Auxiliary Status register). 
Also, this register should never be loaded when the CIP 
or INT bits (in Auxiliary Status) are set to one, and a 
Level II command should never be loaded when the 
BSY bit is set to one. 


The Single-Byte Transfer (SBT) bit in the Command 
register is only used during information transfer type 
commands. When this bit is set in conjunction with one 
of these commands, the transfer counter is disabled 
and exactly one byte is to be transferred, regardless of 
the value in the Transfer Count register. 

Refer to the Commands section for a description of the 
commands and their corresponding command codes. 
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6.2.21 DATA REGISTER [Address 19 Hex] 

The DATA register is used to transfer data bytes 
between the host and the SCSI bus during the SCSI 
information transfer phases (command, data, status, or 
message phase). It may be accessed by the processor 
during any type of information phase (simple Level II 
commands) or via the DMA/WD BUS interface during a 
SCSI Data In phase or Data Out phase (simple and 
combination Level II commands). 

The DATA register is actually a port for the host interface 
into the interval twelve byte FIFO of the WD33C93A. 
The FIFO is used for all transfers (synchronous and 
asynchronous) between the SCSI bus and the host bus, 
for both DMA and processor access transfers. If the 
WD33C93A is to be halted for any reason (through 
ABORT, for example), then data transfers with this FIFO 
must continue until an interrupt occurs. This must be 
done so that the FIFO is returned to a ready state for 
subsequent transfers, and to flush incoming data to the 
host bus. 

The DATA register is accessed by the host processor 
during a data phase when the CONTROL register DMA 
mode select bits are all reset ( = 0), and when the DBR 
bit in the Auxiliary Status register is true. The processor 
writes (reads) the DATA register by loading the Address 
register with a Hex value of 19 and asserting the WE- 
(RE-) and CS- pins. This access also occurs during 
non-data phases. 

When the Control register DMA mode selects bits are 
set for DMA mode or Burst mode, the DMA interface is 
enabled. In this case, the DATA register is written (read) 
when the DACK- and WE- pins are asserted in response 
to the assertion by the WD33C93A of the DRQ- pin. 

When the WD-BUS is selected by the DMA mode select 
bits, the RCS- pin functions as an external buffer chip 
select and the WE- and RE- pins become outputs, 
allowing the WD33C93A to automatically transfer data 
between its DATA register and the external buffer. In this 
mode, bus control can be returned to the external 
processor or any device by negating the DRQ pin. 

6.3 RESET CONDITIONS 
6.3.1 HARDWARE RESET 

The following results occur when the WD33C93A is 
reset by the assertion of the MR- signal: 

• The LCI and PE bits in the Auxiliary Status register are 
reset to zero. The DBR bit in the Auxiliary Status 
Register is reset to zero. The BSY and CIP are reset to 
zero, and the INT bit (and INTRQ pin) is set to one 
when the hardware reset is complete. 


• The Own ID register is reset to zero. 

• Advanced mode is disabled. 

• The ES, ER, and DSP bits in the Source ID register 
are reset to zero. 

• The SCSI Status register is reset to zero. 

• The internal FIFO, internal transfer counter (not the 
host accessible register), offsets, and state machines 
are cleared. 

• The internal clock divider circuit is set to divide by two. 

• The following host accessible registers are NOT 
affected by the MR- signal: 

• Registers 01 Hex through 15 Hex; 

• Source ID (16 Hex) register bits 0-3; 

• Command register (18 Hex). 

NOTE: The SCSI Soft Reset may be implemented by 
using the SCSI bus reset signal to cause a reset of the 
WD33C93A (for example, OR the host power on reset 
signal with the received SCSI bus reset (RST) signal). 
The host may examine the registers that are not 
affected by the MR- signal to recover from the SCSI 
reset condition. 

6.3.2 SOFTWARE RESET 

The following results occur when the WD33C93A 
executes the Reset command: 

• The DBR bit in the Auxiliary Status register is reset to 
zero. The INT bit (and INTRQ pin) is set to one when 
the Reset command is complete. 

• All SCSI bus signals are reset to the negated state. 

• The internal FIFO, internal transfer counter, offsets, 
and state machines are cleared. 

• The Own ID register is interpreted and the clock 
divisor, host parity, and advanced mode are 
configured. 

• Registers 01 Hex through 16 Hex are reset to zero. 
The Command register (18 Hex) is also reset to zero. 

• The SCSI Status register is set as commanded by the 
EAF bit in the Own ID register. 
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7. COMMANDS 
7.1 COMMAND LISTS 


COMMAND 

CODE 

(Hex) 

COMMAND 

VALID 

STATES 

LEVEL 

00 

Reset 

D,T,I 

1 

01 

Abort 

D,T,I 

1 

02 

Assert ATN 

1 

1 

03 

Negate ACK 

1 

1 

04 

Disconnect 

T, 1 

1 

05 

Reselect 

D 

II 

06 

Select-With-ATN 

D 

II 

07 

Select-Without-ATN 

D 

II 

08 

Sel w/ATN-And-Transfer 

D,l 

II 

09 

Sel w/o ATN-And-Transfer 

D,l 

II 

0A 

Reselect-And-Receive Data 

D 

II 

0B 

Reselect-And-Send Data 

D 

II 

OC 

Wait-For-Select-And-Receive 

D 

II 

OD 

Send-Status-And-Command-Complete 

T 

II 

OE 

Send-Disconnect-Message 

T 

II 

OF 

Set IDI 

D,T,I 

1 

10 

Receive Command 

T 

II 

11 

Receive Data 

T 

II 

12 

Receive Message Out 

T 

II 

13 

Receive Unspecified Info Out 

T 

II 

14 

Send Status 

T 

II 

15 

Send Data 

T 

II 

16 

Send Message In 

T 

II 

17 

Send Unspecified Info In 

T 

II 

18 

Translate Address 

D,T 

II 

20 

Transfer Info 

1 

II 


WD33C93A valid states: 

D = Disconnected 

T = Connected as a Target 

I = Connected as an Initiator 

Command Levels: 

I = Level I command 

II = Level II command 
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7.2 WD33C93A COMMAND TYPES 

There are two basic types of WD33C93A commands: 
Level I and Level II. Level I commands may be issued 
while a Level II command is in progress (indicated by an 
Auxiliary Status of BSY = 1 , CIP = 0) and, except for the 
“Abort” and “Reset” commands, do not generate an 
interrupt upon their completion. Level II command 
execution will always result in an interrupt. If a Level II 
command is issued while another Level II command is 
executing, unpredictable results may occur. 

There are two types of Level II commands. ‘Simple’ 
Level II commands are associated with a single opera- 
tion or phase (for example, selection or information 
transfer). ‘Combination’ Level II commands combine 
multiple phases into a single WD33C93A command to 
minimize interrupt overhead. The Initiator combination 
commands ‘expect’ certain SCSI bus phases at certain 
times during a sequence.These expected phases are 
based on common sequences performed by a Target on 
the SCSI bus; any deviation causes an interrupt. Target 
combination commands can also be chained together 
to minimize interrupt overhead by creating longer 
phase sequences. 

NOTE: When using command chaining, care must be 
taken to ensure that all commands in the chain are 
initialized prior to issuing the command. 

The WD33C93A will be in one of three “states” during 
operation: Disconnected, Connected as a Target, or 
Connected as an Initiator. Certain commands are valid 
only in particular states as indicated in the Command 
List. An attempt to issue a Level II command which is 
invalid for the present WD33C93A state will cause an 
“invalid command” interrupt. Level I commands issued 
in invalid states will be ignored. 

7.3 ADVANCED MODE FEATURES 

The WD33C93A has several new features included 
which add new functions to the original WD33C93 
design. Some of these features cause the WD33C93A 
to be incompatible with the WD33C93. These features 
have been grouped together under the heading of 
‘Advanced Mode’ features. These features are disabled 
when the WD33C93A is reset by the MR- signal (hard- 
ware reset). They must be enabled by the host by 
issuing the ‘Reset’ command with the ‘Enable 
Advanced Features’ (EAR) bit set in the Own ID register. 
The host can determine if advanced features have been 
enabled (thereby implying that a WD33C93A is 
installed) by examining the SCSI status register after 
issuing the ‘Reset’ command. 

The features enabled by this bit are described below. 

7.3.1 UNEXPECTED RESELECTION: 

When in normal mode, a reselection when idle (ER = 1) 
or when disconnected during a Select-And-Transfer 
command (and the Target bus ID does not match the 
Destination ID register) causes an immediate interrupt 
after the reselection handshake is complete. In 
Advanced Mode, the WD33C93A will continue to the 
Message In phase to fetch the Identify message. If the 


WD33C93A was idle, the SCSI status register will be 
set to 81 Hex, and the Identify message will be in the 
Data register. If the WD33C93A was executing a Select- 
And-Transfer command, the SCSI status register will be 
set to 27 Hex, and the Identify message will be in the 
Target LUN register. In either case, the Source ID regis- 
ter will contain the SCSI bus ID of the reselecting Target, 
and the ACK signal remains asserted so that the Iden- 
tify message may be rejected. 

7.3.2 UNKNOWN SCSI COMMAND GROUPS 

When a SCSI Command Descriptor Block is transferred 
on the SCSI bus, the command length in bytes is 
determined by the group code, which is found in bits 7-5 
of the first command byte, or opcode. Group 0 (opcodes 
00 to IF Hex), group 1 (opcodes 20 to 3F Hex), and 
group 5 (opcodes AO to BF Hex) commands are defined 
by the SCSI standard (X3. 131-1986) as six, ten, and 
twelve byte commands, respectively. All other com- 
mand groups are undefined by that standard. In normal 
mode, the WD33C93A will assume that these 
undefined groups are six byte commands when execut- 
ing Select-And-Transfer or Wait-For-Select-And- 
Receive commands. In Advanced Mode, the following 
events will occur: 

• Select-And-Transfer: When loading the CDB into 
the CDB registers prior to issuing the command, the 
host also loads the expected command length into 
the OWN ID register. The WD33C93A uses this value 
to make sure the correct number of bytes are then 
transferred in the command phase. 

• Wait-For-Select-And-Receive: When receiving the 
CDB from the Initiator, the WD33C93A will check the 
first CDB byte as soon as it is received. If the group is 
undefined, an interrupt will occur so that the host 
processor can examine the first command byte in the 
CDB 1ST register, and then load the Total command 
length into the Own ID register. The SCSI status 
register is set to 87 Hex, and the Command Phase 
register is set to 31 Hex, when this interrupt occurs. 

After the interrupt, the WD33C93A will only accept a 
Resume Wait-For-Select-And-Receive command, 
Abort, Disconnect, or Reset command. All other com- 
mands are invalid; during the interrupt processing, the 
WD33C93A will continue to transfer the first six bytes of 
the command into its internal FIFO. 

7.3.3 DATE PHASE DIRECTION 

During a Select-And-Transfer command in normal 
mode, the Data phase direction is determined solely by 
the Target; if this direction does not match the direction 
expected by the host, the WD33C93A will not detect this 
error but expects that the transfer will continue. In 
Advanced Mode, the DPD bit in the Destination ID 
register is compared with the state of the I/O signal on 
the SCSI bus. If the expected and actual directions do 
not match, an interrupt will occur with ‘unexpected 
phase’ status in the SCSI status register. 
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7.4 LEVEL I COMMANDS 

7.4.1 RESET (00 HEX) 

The Reset command performs a similar function to the 
hardware reset caused by asserting the MR- pin except 
that the Own ID register is sampled for information con- 
cerning the operating configuration of the WD33C93A. 
The WD33C93A is also initialized as described in the 
RESET CONDITIONS section. The Reset command may 
be executed in any WD33C93A state and will force the 
WD33C93A into the Disconnected state, aborting any 
previously issued command in progress. Upon comple- 
tion of the Reset command, an interrupt is generated the 
SCSI STATUS will be 00 Hex or 01 Hex, depending on the 
contents of the OWN ID register. 

7.4.2 ABORT (01 HEX) 

The Abort command is valid in any WD33C93A state: 
Disconnected, Target, or Initiator. The Abort command 
has different effects depending on the state and the 
command that is currently executing, as described below: 

Disconnected State: In the Disconnected state, the Abort 
command may be used to halt an attempted Select, 
Select-and-Transfer, Reselect, or Reselect-and-Transfer 
command. If the Abort command is issued following a 
Select or Reselect command and the WD33C93A has 
won arbitration, the WD33C93A releases the SCSI bus by 
removing the Bus ID bits while SEL- is asserted and 
checking for a negated BSY- signal. If, after at least 200 
IjlS, there is no BSY- response, the WD33C93A goes to a 
Bus Free condition, and a “paused/aborted” interrupt is 
generated. If there is a response within this time period, 
then a “successful completion” interrupt will result 
instead. If the WD33C93A has not yet won arbitration, it 
will immediately abort the Select or Reselect command. 

Target State: When the WD33C93A is in a Connected as 
a Target state, the Abort command may be used to abort 
RECEIVE, SEND, or the data phase portion of a Target 
combination command. When issuing an Abort in the 
Connected as a Target state, the following rules apply: 

1. When an Abort command is issued to abort a SEND 
or Reselect-and-SEND command, the local processor 
must not service any data request (DBR, DRQ, etc.) from 
the WD33C93A until an interrupt from the WD33C93A 
occurs. This is required to allow the FIFO to clear; the 
Abort processing will not complete until the FIFO contents 
are flushed to the SCSI bus. The WD33C93A removes 
the data request at an arbitrary time during the Abort 
command processing and the data request is not valid 
once the Abort command is written to the COMMAND 
register. 

2. When an Abort command is issued to abort a 
RECEIVE or Reselect-and-RECEIVE command, the 
local processor must CONTINUE to service any data 
request (DBR, DRQ, etc.) from the WD33C93A until an 
interrupt from the WD33C93A occurs. This is required to 
allow the FIFO to clear; the Abort processing will not 
complete until the FIFO contents are flushed to the local 
processor. 

After the Abort command is processed and the local 


processor has received the interrupt indicating this, the 
TRANSFER COUNT register contains the number of 
bytes that were not successfully transferred with the SCSI 
bus. The WD33C93A remains in the connected as a 
Target state. The WD33C93A is now ready to receive any 
appropriate Target mode command, including a resume 
of the command that was aborted. 

Initiator State: When the WD33C93A is in a connected as 
an Initiator state, the Abort command may be used to 
abort TRANSFER INFO, TRANSFER PAD, Select, or 
Select-and-TRANSFER command. When issuing an 
Abort in the connected as an Initiator state, the local 
processor must continue to service any data request 
(DBR, DRQ, etc.) from the WD33C93A until an interrupt 
from the WD33C93A occurs. This is required to allow the 
FIFO to clear; the Abort processing will not complete until 
the FIFO contents are flushed to the data destination. 
After the Abort command is processed and the local 
processor has received the interrupt indicating this, the 
TRANSFER COUNT register contains the number of 
bytes that were not successfully transferred with the SCSI 
bus. The WD33C93A remains in the connected as an 
Initiator state. The WD33C93A is now ready to receive 
any appropriate Initiator mode command, including a 
resume of the command that was aborted. 
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7.4.3 DISCONNECT (04 HEX) 

The Disconnect command may be used in either the 
Target or the Initiator connected states. In the Target role, 
the Disconnect command is the normal procedure for 
disconnecting from the SCSI bus following the informa- 
tion transfer phase. In the Initiator role, Disconnect can be 
used to release the bus following a timeout condition. The 
Disconnect command causes the immediate release of 
all bus signals and, in Target mode, returns the SCSI bus 
to the Bus Free phase. If the Disconnect command is 
issued during an active Level II command, the Level II 
command is immediately terminated and the WD33C93A 
transitions to the Disconnected state. 


7.4.4 ASSERT ATN (02 HEX) 

The Assert ATN command is only valid when Connected 
as an Initiator. It is normally used to allow the Initiator to 
inform a Target that it has a message pending (the Target 
is expected to respond by performing a Message Out 
Phase). 

ATN- is automatically negated: 

• before the last byte of a Transfer Info command issued 
in response to the Message Out phase; 

• when the Identify message out is transferred to the 
Target during a Select-and-Transfer command; 

• when a SCSI Bus Free phase occurs. 

The Select-with-ATN and Select-with-ATN-and-Transfer 
commands will cause the WD33C93A to automatically 
assert ATN - prior to the release of SEL- providing the bus 
arbitration is won. 
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7.4.5 NEGATE ACK (03 HEX) 

The Negate Ack command causes ACK- to be negated. It 
is used when Connected as an Initiator following Mes- 
sage-In type Transfer Info commands, or when the 
WD33C93A has detected a parity error on any received 
information and the Halt on SCSI Parity Error (HSP) bit is 
set. Host parity errors do not affect the ACK- signal. For all 
other Initiator transfers, ACK- negation is automatic. 

In the case of a Message-In transfer, incoming messages 
may be rejected and the Initiator may indicate its intent to 
send either a “Message Reject” or a “Message Parity 
Error” Message by issuing the Assert ATN command prior 
to issuing the Negate Ack command. If the incoming 
message is to be accepted, only the Negate Ack com- 
mand should be issued. 

During non-Message-ln transfers, if the Transfer com- 
mand is terminated by parity error, the Assert ATN com- 
mand can again be issued prior to Negate ACK, this time 
indicating the Initiator’s intent to send an “Initiator 
Detected Error” Message. 

7.4.6 SET IDI (OF HEX) 

The Set IDI command is used in the Initiator role to 
support overlapped SCSI operations. If a SCSI command 
is executing via a Select-and-Transfer command, then the 
Set IDI command may be used to set the IDI bit in the 
Control register, which then causes an interrupt to occur 
upon a Target disconnection. This ability allows the IDI bit 
to be left reset when the first SCSI operation is started, 
which may reduce the number of WD33C93A interrupts, 
yet also allows a second operation to be started when 
needed without waiting for the first operation to be 
completed. 

7.5 SIMPLE LEVEL II COMMANDS 

7.5.1 SELECT-WITH-ATN (06 HEX) 

Select-with-ATN is valid only in the Disconnected state 
and when issued will cause the WD33C93A to select a 
Target. Before issuing this command, the SCSI Bus ID 
of the Target device should be written into the Destina- 
tion ID register. When the Select-with-ATN command is 
issued, the WD33C93A begins bus arbitration. If the 
WD33C93A is selected or reselected by another device 
during the arbitration, the Select-with-ATN command is 
aborted and a “service required” interrupt (8x Hex) is 
generated. 

Should the WD33C93A win the arbitration, SEL- and 
ATN- are asserted, the Target and Initiator Bus IDs are 
placed on the SCSI data bus, and then BSY- is 


deasserted. At this time, a timeout sequence whose 
length is determined by the value in the Timeout Period 
register begins. If BSY- is not asserted by the Target 
before a timeout occurs, the WD33C93A begins its 
selection abort sequence (as described in the Abort 
command description), and if there is no Target 
response the Select-with-ATN command is terminated 
and a “terminated” interrupt is generated. If the Target 
responds before the timeout period has elapsed or 
before the selection abort sequence is complete, the 
WD33C93A negates the Sel- signal, putting the 
WD33C93A in a Connected-as-an-lnitiator state. A 
“successful completion” interrupt indicates that the 
Select-with-ATN command has been completed 
successfully. 

If the WD33C93A does not win the arbitration or there is 
no response from the Target and the timeout feature is 
disabled, the Select-with-ATN command can be 
aborted with an Abort command. When the Abort com- 
mand is successfully executed under these circum- 
stances, the WD33C93A is disconnected from the bus 
and a “paused/aborted” interrupt is generated. 

7.5.2 SELECT-WITHOUT-ATN (07 HEX) 

The Select-without-ATN command is identical to the 
Select-with-ATN command except that ATN- is not set 
during the Selection Phase. 

7.5.3 RESELECT (05 HEX) 

The Reselect command is identical to the Select-with- 
out-ATN command except that the I/O signal is asserted 
upon completion of the Arbitration Phase. Successful 
completion of the Reselect command results in the 
WD33C93A being Connected as a Target. 

7.5.4 RECEIVE (10-13 HEX) 

There are four RECEIVE commands which are dis- 
tinguished from each other only by the state of three 
SCSI interface signals and the type of data that is 
transferred. These commands, consisting of the 
Receive Command, Receive Data, Receive Message 
Out, and Receive Unspecified Info Out commands are 
valid only in the Connected-as-a-Target state. The type 
of Receive command selected determines the state of 
the I/O-, C/D-, and MSG- outputs during the command 
according to the following chart below (1 = asserted). 

The Receive commands are information transferring 
commands and are therefore dependent on the SBT bit 
in the Command register for determination of a suc- 
cessful completion. In addition to a termination caused 


RECEIVE COMMAND TYPE 

OPCODE 

MSG 

C/D 

I/O 

Receive Command 

10 

0 

1 

0 

Receive Data 

11 

0 

0 

0 

Receive Message Out 

12 

1 

1 

0 

Receive Unspecified Info Out 

13 

1 

0 

0 


23 
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by reset (via either a Reset command being issued or 
assertion of the MR- pin), a Receive command comple- 
tion or termination will occur under any of these condi- 
tions: (1) The internal transfer counter is disabled 
(SBT = 1 or the Transfer Count register is loaded with 
zero) and a single byte has been read from the Data 
register; (2) The counter has decremented to zero (with 
SBT = 0) indicating that the specified number of bytes 
have been transferred; (3) A parity error has been 
detected on one of the received data bytes (and 
HSP = 1); (4) The ATN- pin is asserted (and HA = 1); (5) 
The Abort command is issued; or (6) A Disconnect 
command is issued. 

When the Receive command is completed as a result of 
receiving the correct number of bytes, a “successful 
completion” interrupt will be generated. If a parity error 
has caused termination, a “terminated” interrupt will 
instead be generated. In this case, the Transfer Count 
register will contain the number of bytes yet to be 
transferred. After any completion or termination of the 
Receive commands except those due to a subsequent 
Disconnect command or reset, the WD33C93A is in the 
Connected-as-a-Target state. 

As data transfer commands, the Receive commands 
are dependent on the DMA mode select bits in the 
Control register for the Data register accessing mode. 
These bits determine whether the Data register 
accesses will be handled by the processor or through a 
DMA/WD interface. When the processor is required to 
read the Data register (i.e. DMA mode select bits = 0), it 
must monitor the DBR status bit (in Auxiliary Status) to 
determine when a byte is available for reading. During 
Receive commands, this status bit will be reset when a 
byte is read from the Data register and set when a byte 
is loaded into the Data register via the SCSI interface. 
DBR is also reset when a Receive command is issued. 

All information transfers involving other than data infor- 
mation are asynchronous. However, if the information 
phase involves data transfers, the Synchronous Trans- 
fer register will be evaluated. In this case, any selected 
offset other than zero results in synchronous transfers. 
The minimum Transfer Period for both types of transfers 
is determined by the transfer period bits in this same 
register. 

7.5.5 SEND (14-17 HEX) 

As in the case of the RECEIVE commands, there are 
four Send commands which are distinguished only by 
the state of the I/O-, C/D-, and MSG- pins and the type 
of data that is transferred. The four Send commands, 
also valid in the Connected-as-a-Target state only, are 


the Send Status, Send Data, Send Message In, and 
Send Unspecified Info In commands. The SCSI pin 
states during the Send commands are determined by 
the particular commands as follows shown in the chart 
below (asserted = 1). 

The Send commands are also information transferring 
commands and as such are also dependent upon the 
SBT bit in the Command register for command comple- 
tion. In addition to that caused by reset (via either a 
Reset command being issued or assertion of the MR- 
pin), a Send command completion or termination will 
occur under any of these conditions: (1) The internal 
transfer counter is disabled (SBT = 1 or the Transfer 
Count register is loaded with zero) and a single byte has 
been read from the Data register; (2) The counter has 
decremented to zero (with SBT = 0) indicating that the 
specified number of bytes have been transferred; (3) A 
parity error has been detected on one of the data bytes 
from the host (and HHP = 1); (4) The ATN- pin is 
asserted (and HA = 1); (5) The Abort command is is- 
sued; or (6) A Disconnect command is issued. The 
WD33C93A remains Connected-As-A-Target following 
the Send command completion/termination unless the 
Disconnect command or reset was used to force a 
termination. 

During a Send command, Data register accessing is 
controlled by the DMA mode select bits in the Control 
register. When these bits are set to the appropriate 
mode, loading of the Data register is accomplished by a 
DMA controller or through the WD-Bus interface. If the 
DMA mode select bits are zero, the processor must poll 
the Auxiliary Status register and can write to the Data 
register only when the Data Buffer Ready bit is set 
(DBR = 1). Send commands cause the DBR bit to be 
reset every time the processor loads a byte into the 
Data register and set when a byte is transferred from 
the Data register onto the SCSI data bus. The DBR bit 
will also be set upon issuing a Send command. 

As in the case of Receive commands, synchronous 
transfers will occur only when data transfers are 
involved and an offset other than zero is selected. 



7.5.6 TRANSFER (20 HEX) 

Transfer Info is used to send and receive data, com- 
mand, status, and message information. 


SEND 

COMMAND TYPE 

OPCODE 

MSG 

C/D 

I/O 

Send 

Status 

14 

0 

1 

1 

Send 

Data 

15 

0 

0 

1 

Send 

Message In 

16 

1 

1 

1 

Send 

Unspecified Info In 

17 

1 

0 

1 
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The first Req- assertion following connection as an 
Initiator results in a “service required” interrupt. The 
processor should examine the SCSI Status register to 
determine the type and direction of information transfer 
requested by the Target, and then issue a Transfer Info 
command in response. While an Initiator, the 
WD33C93A will also generate an interrupt each time 
the Target device requests a new type of information 
transfer phase. 

As in the case of the Send and Receive commands, 
when the Transfer Info command completion is to be 
dependent upon the internal transfer counter, the pro- 
cessor should load the Transfer Count register prior to 
issuing this command. The DMA mode select bits in the 
Control register, the offset and transfer period bits in the 
Synchronous Transfer register, and the SBT bit in the 
Command register are used during Transfer Info com- 
mands just as they are during the Send-And-Receive 
commands. However, for processor access of the Data 
register during Transfer Info commands (when the DMA 
mode select bits are zero, or the bus phase is other than 
Data phase), behavior of the Data Buffer Ready (DBR) 
status bit is determined by the direction of information 
transfer as defined by the I/O- pin. When the transfer is 
from Initiator to Target, the DBR bit is reset by writing to 
the Data register and is set when the byte is transferred 
from the Data register onto the SCSI data bus. When 
the transfer is from Target to Initiator, DBR is set when a 
byte is received over the SCSI data bus and transferred 
into the Data register and is reset by reading the Data 
register. DBR is also reset whenever a Transfer Info 
command is issued. 

There are several causes of a Transfer Info command 
completion/termination in addition to a reset. Just as for 
a Send or Receive command, the Transfer Info com- 
mand can be terminated by issuing a subsequent Dis- 
connect or Abort command. The Abort command will 
caqse a “paused/aborted” interrupt to be generated 
after execution (leaving the WD33C93A in a connected 
state), while the Disconnect command causes an imme- 
diate disconnect and does not generate an interrupt. 

A Transfer Info command will be either completed or 
paused when the specified number of bytes (either a 
single byte or multiple bytes as defined by the Single- 
Byte Transfer bit in the Command register) have been 
sent or received. The WD33C93A generates a “suc- 
cessful completion” interrupt only after receiving 
another REQ- from the Target during non-Message In 
information phases, but generates a “paused/aborted” 
interrupt for Message-In phases without waiting for an 
additional REQ- (Note that when the completed Trans- 
fer Info command was a Message-In transfer phase, the 
ACK- pin will be left asserted by the WD33C93A,in the 
last REQ-ACK cycle of the command, and the pro- 
cessor is required to issue a negate ACK or an Assert 
ATN followed by a Negate ACK command to accept or 
reject the message respectively). 


If a parity error is detected on a data byte received from 
the SCSI bus (and HSP = 1), or on a data byte received 
from the host (and HHP = 1), then the WD33C93A will 
terminate the command and, for SCSI parity errors, will 
leave ACK- asserted (to also halt the Target). In this 
case a “terminated” interrupt is generated. Finally, 
negation of the BSY- signal (i.e. the Target suddenly 
disconnects) or a transition in the I/O-, C/D-, and/or 
MSG- pins during a Transfer command will also termi- 
nate the command and generate a “terminated” 
interrupt. 

If a parity error is detected on a received byte but parity 
error command termination is disabled (HSP = 0 or 
HHP = 0, as appropriate), the WD33C93A will still set 
the Parity Error status bit in the Auxiliary Status register 
but will not terminate the command as a result of this 
error. 

7.5.7 TRANSLATE ADDRESS (18 HEX) 

The Translate Address Command is used to perform a 
logical-to physical-address translation. Certain SCSI 
commands involve a logical address which may be up to 
32 bits in length. When a command is detected which 
requires address translation, the processor can reload 
the logical address into the WD33C93A Logical 
Address register and then issue the Translate Address 
command to have the WD33C93A do the conversion. 
Upon receiving a “successful completion” interrupt, the 
processor can read three WD33C93A registers to 
extract the Cylinder Number, Head Number, and Sector 
Number corresponding to the logical address. The disk 
parameters contained in the Total Sectors, Total Heads, 
and Total Cylinders registers must also be valid before 
issuing a Translate Address command. 

If automatic compensation for spare sectors is to be 
performed by the WD33C93A, then the number of 
spare sectors per cylinder and total number of sectors 
per cylinder must also be loaded in the Head Number 
and Cylinder Number registers respectively. A “termi- 
nated” interrupt will occur if any division operation 
performed during this command results in an overflow. 


7.6 COMBINATION LEVEL II COMMANDS 

7.6.1 SELECT-AND-TRANSFER 
(08 AND 09 HEX) 

The Select-And-Transfer commands are capable of 
greatly reducing the host or local processor interrupt- 
handling burden by enabling the WD33C93A’s internal 
microprocessor to manage the low-level SCSI protocol. 
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This results in as few as one interrupt per SCSI opera- 
tion. Select-And-Transfer commands are used when in 
an Initiator role, and typically consist of at least the 
following SCSI phases: (1) Selection of a Target device; 
(2) Sending of a command; (3) Reception of status 
information; and (4) Reception of a Command Com- 
plete Message. These commands optionally consist of 
a Data Transfer phase and additional Message Transfer 
phases. During execution of a Select-And-Transfer 
command, the Command Phase register will be 
updated to indicate which bus phases of the SCSI 
operation have been completed, so that upon comple- 
tion or termination of the command, the WD33C93A 
may be interrogated to find out where the SCSI opera- 
tion was stopped. 

The two Select-And-Transfer commands are dis- 
tinguished from each other only by whether or not the 
ATN- pin is asserted during the Selection phase. Select- 
And-Transfer commands directly support Group 0 (6- 
byte CDB), Group 1 (10-byte CDB), and Group 5 (12- 
byte) SCSI commands. In addition, the ability to have 
ATN- asserted during Selection supports the SCSI 
Message Protocol which calls for an Identify Message 
Out phase following the Selection. When the Select 
w/Atn-And-Transfer commands is issued, the 
WD33C93A expects the first information phase request 
from the Target to be a Message Out phase, whereas for 
a Select w/o Atn-and-Transfer command, the first infor- 
mation phase request is expected to be a Command 
Out phase. 

When a Select-And-Transfer command is issued, the 
WD33C93A arbitrates for the bus and selects a Target 
just as during a Select command. If the Target does not 
respond before a timeout occurs, the Select-And-Trans- 
fer command is terminated and a “terminated” interrupt 
is generated. Failure to complete the Selection phase is 
also indicated by the fact that the Command Phase 
register contains all zeroes. If the Selection is success- 
ful, no interrupt is generated, but the Command Phase 
register will be set to a Hex 10. 

After completing the Selection phase, the WD33C93A 
begins an information transfer phase. If ATN- has been 
asserted (i.e. a Select w/Atn-And-Transfer command 
was issued), the WD33C93A expects the Target to 
respond with a Message Out phase. If the first informa- 
tion phase request is other than a Message Out 
request, the WD33C93A will terminate the command 
and generate a “terminated” interrupt. However, when 
the Target does request a Message Out phase, the 
WD33C93A will respond by automatically sending an 
Identify Message. This single byte message is of the 
binary form: 1 rOOOttt, where r=1 if the Enable Reselect 
bit in the Source ID register is equal to 1, and ttt is the 
encoded Target Logical Unit Number contained in the 
Target LUN register. Once the Identify Message has 
been sent, the WD33C93A will set the Command Phase 
register to Hex 20. 

Following the Message Out phase (or Selection phase 
when ATN- was not asserted during Selection), a Com- 
mand phase is expected by the WD33C93A. Again, and 


throughout the entire Select-And-Transfer command 
execution, if the Target requests an unexpected infor- 
mation phase type, the WD33C93A terminates the 
command and generates a “terminated” interrupt. If 
the Command phase is requested in this situation, the 
WD33C93A will extract the SCSI command from the 
internal Command Descriptor Block registers and send 
6, 10, or 12 bytes of command information as deter- 
mined by its evaluation of the SCSI command code in 
the CDB1 register. The Command Phase register is set 
to Hex 30 before the first Command byte is sent and 
then increments with each byte transferred, so that for a 
12-byte CDB command the Command Phase register 
will contain Hex 3C when all bytes of the CDB have been 
transferred. 

After the Command phase, the WD33C93A expects 
either a Data In phase, Data Out phase, Status phase, 
or Message In phase. If the Target is requesting a 
Message In phase, a pending disconnection is 
assumed. The WD33C93A therefore expects to receive 
either a Save Data Pointer Message (Hex 02) or a 
Disconnect Message (Hex 04). If either message is 
incorrect, or if a different message is received, a “termi- 
nated” interrupt will be generated to alert the processor 
of that fact and to allow the message to be read from the 
Data register. A “terminated” interrupt will also be gen- 
erated if the Target disconnects before sending the 
Disconnect message. When a correct Save Data 
Pointer message is received, a “paused/aborted” inter- 
rupt is generated and the Select-And-Transfer com- 
mand terminated to allow the processor to save the 
SCSI data pointers. However, if a Disconnect message 
is received, the Command Phase register will be 
updated to Hex 42 and command execution continues. 

When the actual Target-disconnection does occur, the 
Command Phase register is updated to Hex 43 and if 
the IDI bit is set, the WD33C93A terminates the Select- 
And-Transfer command by generating an 85H interrupt. 
However, if the IDI bit is reset, then instead the 
WD33C93A sits in an idle state, waiting for the Target to 
reconnect. If a different Target device Reselects the 
WD33C93A, a “terminated” interrupt is generated. 
However, if the original Target Reselects the 
WD33C93A, no interrupt is generated and the Com- 
mand Phase register is set to Hex 44. 

Following the original Target Reselection, the 
WD33C93A expects a Message In phase which should 
consist of the Target sending an Identify Message. This 
single-byte message should be of the binary form: 
lOOOOttt, where ttt is the Target Lun. If the data received 
by the WD33C93A is different or the Target Lun spec- 
ified in this byte does not match the contents of the 
Target Lun register, a “terminated” interrupt is gener- 
ated and the Message byte may be examined by 
the processor. A correct Identify Message In phase re- 
sults in the Command Phase register being updated 
to Hex 45. 

After the Identify Message is received from the Target or 
immediately after the Command Out phase (when there 
is no disconnection), a Data In phase, Data Out phase, 
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or Status phase should occur. If the Transfer Count 
register contains any non-zero value, then the 
WD33C93A will expect a Data Transfer phase. If 
Advanced Features are enabled, then the DPD bit will 
be examined to verify the correct data direction. If the 
data direction is incorrect, then a “terminated” interrupt 
is generated. In this phase, the WD33C93A will use the 
Transfer Count register to determine the number of 
bytes to be transferred, and all host-side Data register 
accesses will be accomplished via the method selected 
by the DMA mode select bits in the Control register. 
When the internal counter reaches zero, the Data 
Transfer phase is complete and the Command Phase 
register is set to Hex 46. 

Note that any number of disconnection/reconnection 
cycles may occur during the Data Transfer phase so 
long as they are accomplished according to the defined 
message protocol. The Command Phase register will 
cycle through the disconnect phases (41-45) with each 
disconnection, and subsequent reconnection until all of 
the data has been transferred and the Data Transfer 
phase is complete. 

A Status phase is expected by the WD33C93A following 
the Data Transfer phase (or instead of the Data Transfer 
phase when the Transfer Count register contains a 
value of zero). At the start of the Status phase, the 
Command Phase register is loaded with Hex 47. Upon 
completion of the Status phase, the Command Phase 
register will be updated to Hex 50, and the received 


status byte is stored in the Target Lun register where it 
can be read upon completion of the command. 
Following completion of the status-byte transfer, a Mes- 
sage In phase is expected. The WD33C93A expects the 
Target to send a Command Complete Message (Hex 
00) to indicate that the SCSI command operation has 
been completed. After the WD33C93A receives this 
Command Complete Message, the Command Phase 
register advances to Hex 60, and if the EDI bit is reset, a 
“successful completion” interrupt is generated. The 
processor should then read the Target Lun register to 
examine the Target status. An additional interrupt will 
then occur when the SCSI bus goes to the Bus Free 
state, or when another REQ- is asserted to begin an 
information transfer phase (as in SCSI linked com- 
mands). If the EDI bit is set, the “successful completion; 
interrupt will be suppressed until the Target disconnects 
from the SCSI bus. 

At any time during execution of the Select-And-Transfer 
commands, an abnormal or unexpected condition will 
cause the WD33C93A to terminate the command, set 
the appropriate status qualifiers, and generate a “termi- 
nated” interrupt. If the termination occurred during an 
information transfer phase, the WD33C93A will be left 
in a Connected-as-an-lnitiator state (unless termination 
was due to a sudden Target disconnection). Command 
termination during any other phase will result in the 
WD33C93A being in a Disconnected state. Transfer 


COMMAND 

PHASE 

MEANING 

00 

No SCSI bus device has been selected. The WD33C93A is in the disconnected state. 

10 

The Target has been selected. The WD33C93A is now in the connected as an Initiator 
state. 

20 

An Identify message has been sent to the Target. 

30 

Command phase has started, no bytes transferred. 

3x 

Command phase, x bytes have been transferred. 

41 

Save Data Pointer message received. 

42 

Disconnect message received, bus not free. 

43 

Target has disconnected (SCSI bus free) following a successful transfer of a 

Disconnect message. The WD33C93A is now in the disconnected state. 

44 

The WD33C93A has been reselected by the Target whose SCSI bus ID matches the 
value in the DESTINATION ID register. The WD33C93A is now in the connected as an 
Initiator state. 

45 

The WD33C93A has received an Identify message from the Target whose Logical Unit 
Number matches the value in the TARGET LUN register. 

46 

The number of bytes specified in the TRANSFER COUNT register have been 
transferred to/from the Target during a Data Out/In phase. 

47 

The Target has begun a Receive Status phase. 

50 

The WD33C93A has successfully received a Status byte from the Target and stored it 
in the TARGET LUN register. 

60 

The WD33C93A has successfully received a Command Complete message from the 
Target. 
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COMMAND 

PHASE 

MEANING 

10 

Resume after Target selection is complete. 

20 

Resume after Identify message out. Command phase is expected; an implied Negate 
ACK occurs. 

30 

Resume when Command phase has begun (REQ- asserted). 

41 

Resume after Command phase or after Save Data Pointer message. Data, Status, or 
Message In phases are expected. An implied Negate ACK occurs. 

42 

Resume to complete Disconnect Message In; an implied Negate ACK occurs. 

44 

Resume after reselection by a Target. 

45 

Resume to transfer more data in a data transfer phase. May expect Status or 

Message In as well. An implied Negate ACK occurs. 

46 

Resume after the data phase has been completed, expecting Status phase or a Save 
Data Pointer/Disconnect Message In phase. An implied Negate ACK does not occur. 

50 

Resume to complete a Status phase; an implied Negate ACK occurs. 

60 

Resume to complete a Command Complete message from the Target; an implied 

Negate ACK occurs. 


commands may be used to handle the exception by 
transferring messages with the Target. 

The following table summarizes the possible values 
that the Command Phase register can take during the 
Select-And-Transfer commands, and their meanings 
relative to command termination: 

A “Resume Select-And-Transfer’’ command is 
assumed whenever a normal “Select-And-Transfer” 
command is issued while the WD33C93A is in the 
Connected-Initiator state. When the “Resume” is iss- 
ued, the WD33C93A examines the Command Phase 
Register to determine where to restart the Select-And- 
Transfer command execution. This feature, in conjunc- 
tion with the Intermediate Disconnect Interrupt 
enabled, allows support of multi-threaded or over- 
lapped I/O on the SCSI bus. 

The table above briefly describes the valid settings of 
the Command Phase register when resuming a Select- 
And-Transfer command: 

7.6.2 RESELECT-AND-TRANSFER 
(OA AND OB HEX) 

The Reselect-And-Transfer commands include the 
Reselect-and-Receive Data and the Reselect-and- 
Send Data commands. These commands cause the 
WD33C93A to execute certain common SCSI bus 
phase sequences as a Target following a Reselection 
phase. These phases are determined by which com- 
mand is sent, and the setting of two bits: the EDI bit in 
the Control Register; and the SCC bit in the Destination 
ID register. The SCSI bus phase sequences are sum- 
marized below. Refer to the command descriptions of 
the Send-Status-And-Command-Complete and Send- 
Disconnect-Message commands for details on those 
sequences. 


(1) Reselect-and-Receive command, EDI = 0, 
and SCC = don’t care: 

• Reselection phase; 

• Send Identify Message In; 

• Receive Data Out phase; 

• Completion interrupt. 

(2) Reselect-and-Send command, EDI = 0, 
and SCC = don’t care: 

• Reselection phase; 

• Send Identify Message In; 

• Receive Data In phase; 

• Completion interrupt. 

(3) Reselect-and-Receive command, EDI = 1 , 
and SCC = 0: 

• Reselection phase; 

• Send Identify Message In; 

• Receive Data Out phase; 

• Chain to Send-Status-and-Command Complete. 

(4) Reselect-and-Send command, EDI = 1 , 
and SCC = 0: 

• Reselection phase; 

• Send Identify Message In; 

• Receive Data In phase; 

• Chain to Send-Status-And-Command Complete. 

(5) Reselect-and-RCV command, EDI = 1 , 
and SCC = 1: 

• Reselection phase; 

• Send Identify Message In; 

• RCV Data Out phase; 

• Chain to Send-Disconnect-Message. 
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(6) Reselect-and-Send command, EDI = 1, 
and SCC = 1: 

• Reselection phase; 

• Send Identify Message In; 

• Send Data In phase; 

• Chain to Send-Disconnect-Message. 

If the reselection attempt times out during a Reselect- 
And-Transfer command, ATN- is asserted and HA = 1, 


or if a parity error is detected on an incoming data byte 
(and HSP = 1 or HHP = 1 , depending on data direction), 
the command will be terminated and the appropriate 
status will be set. In this case, the Command Phase 
register should be evaluated to determine the last suc- 
cessfully completed phase. If none of these conditions 
occurs, all phases complete normally, and if EDI = 0, 
then a “successful completion” interrupt would be gen- 
erated at this point. However, if EDI = 1 , no interrupt is 


COMMAND 

PHASE 

MEANING 

00 

No SCSI bus device has been reselected. The WD33C93A is in the disconnected 
state. 

10 

The WD33C93A has successfully reselected the Initiator. The WD33C93A is now in 
the connected as a Target state. 

20 

The Identify message has been successfully sent to the Initiator. 

46 

The requested data transfer has been completed. 


generated and command chain occurs (as described 
above). 

The following table summarizes the possible values 
that the Command Phase register can take during the 
Reselect-And-Transfer commands, and their meanings 
relative to command termination. See other command 
descriptions for additional values that can occur when 
command chaining is used. 

A “Resume Reselect-And-Transfer” command is 
assumed whenever a normal “Reselect-And-Transfer” 
command is issued while the WD33C93A is in the 


Connected as a Target state. When the “Resume” is 
issued, the WD33C93A examines the Command Phase 
Register to determine where to restart the Reselect- 
And-Transfer command execution. This feature, in con- 
junction with the capability to chain to other combina- 
tion commands, allows longer SCSI bus sequences to 
be executed by a single command. 

The following table briefly describes the meaning of the 
Command Phase register when resuming a Reselect- 
And-Transfer command: 


COMMAND 

PHASE 

MEANING 

10 

Resume after Initiator reselection is complete; start with Identify Message Out. 


Resume after Identify Message Out; start with data transfer phase. If Transfer Count 

20 

is zero, no data transfer phase occurs. In either case, a chain to another combination 


command can occur if enabled. 


7.6.3 WAIT-FOR-SELECT-AND- RECEIVE 
(OC HEX) 

The Wait-For-Select-And-Receive causes the 
WD33C93A to idle until it is selected by an Initiator, at 
which time the WD33C93A will enter the Target mode 
and message and command information will automat- 
ically be requested. As an option, the WD33C93A may 
be programmed to disconnect when a SCSI read com- 
mand is received while executing a Wait-For-Select- 
And-Receive command. Use of this command therefore 
eliminates the interrupts which normally occur after 
selection and after each subsequent SCSI bus phase, 
and results in very short bus-connect time during SCSI 
read commands. 

If ATN- was asserted by the Initiator during the selection 
phase, the WD33C93A will first execute an implied 
“Receive Message Out” command to get the Identify 


message from the Initiator, before continuing on with 
the implied “Receive Command” to receive the SCSI 
command information. The SCSI command information 

(CDB) will be stored in the CDB registers (Hex 
addresses 03 to 0E), and if a valid Identify message is 
received, it will be saved in the Target Lun register (Hex 
address OF). The number of command bytes requested 
by the WD33C93A is determined by the SCSI group 
code in the first byte of the CDB. 

After the WD33C93A is selected and receives all valid 
command and message information, a “successful 
completion” interrupt will normally be generated to 
allow the local processor to read out and interpret the 
SCSI CDB. However, by setting the EDI bit prior to 
issuing a Wait-For-Select-And-Receive command, the 
WD33C93A is enabled to perform an automatic discon- 
nect when a SCSI read command is received. There- 
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fore, when EDI = 1 and the 1st CDB byte received 
contains a 6, 10 or 12 byte read command code, then 
the WD33C93A will temporarily suppress the interrupt 
and chain to begin execution of a Send-Disconnect- 
Message command. An interrupt will then be generated 
after completion of this command, which normally 
would indicate a transition to the bus free condition. 
Refer to the Send-Disconnect-Message command 
description for more details. 

If during execution the message or command informa- 
tion received from the Initiator is invalid, the implied 
receive command will be terminated and the appropri- 
ate status reported. In this case, the Command Phase 
register should be read to determine which phase of the 
Wait-For-Select-And-Receive command was last com- 


pleted before the error condition occurred. A Command 
Phase Hex value of Hex 10 indicates that the 
WD33C93A was successfully selected. A Hex value of 
20 indicates that a message was received from the 
Initiator, and when the WD33C93A begms receiving 
command bytes, the Command Phase is set to Hex 30 
and increments with each byte received (to a maximum 
of 3C for a 12-byte CDB command). 

The following table summarizes the possible values 
that the Command Phase register can take during the 
Wait-For-Select-And-Receive command, and their 
meanings relative to command termination. See other 
command descriptions for additonal values that can 
occur when command chaining is used. 


COMMAND 

PHASE 

MEANING 

00 

The WD33C93A has not been selected. Tbe WD33C93A is in the disconnected state. 

10 

The WD33C93A has been successfully selected by the Initiator. The WD33C93A is 
now in the connected as a Target state. 

20 

The Identify message has been successfully received from the Initiator. 

30 

The WD33C93A has begun command phase by setting the SCSI bus phase signals 
and asserting REQ-. 

31 

The WD33C93A has transferred 1 command byte from the Initiator. The SCSI Status 
may indicate the need for the host to load the command size into the OWN ID register. 

3x 

The WD33C93A has transferred x command bytes from the Initiator. 


A “Resume Wait-For-Select-And-Receive” command is 
assumed whenever a normal “Wait-For-Select-And- 
Receive” command is issued while the WD33C93A is in 
the Connected as a Target state. When the “Resume” is 
issued, the WD33C93A examines the Command Phase 
Register to determine where to restart the Wait-For- 
Select-And-Receive command execution. This feature, 


in conjunction with the capability to chain to other 
combination commands, allows longer SCSI bus 
sequences to be executed by a single command. 

The following table briefly describes the meaning of the 
Command Phase register when resuming a Wait-For- 
Select-And-Receive command: 


COMMAND 

PHASE 

MEANING 

10 

Resume after selection by the Initiator is complete; start with Identify Message Out if 
ATN is asserted, otherwise, start with command phase. 

20 

Resume after a message out; check the received message in the Target Lun register 
for a valid Identify message. 

30 

Resume after Identify message out. Start with command phase. 

31 

Resume after the WD33C93A has transferred 1 command byte from the Initiator. This 
resume point is used only when an unknown group code has been detected in 

Advanced Mode, and the command size has been loaded into the Own ID register. 
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7.6.4 SEND-STATUS-AND-COMMAND- 
COMPLETE (OD HEX) 

The Send-Status-And-Command-Complete command 
is valid in the Target role, and is used to complete a 
SCSI operation by transferring the appropriate status 
information to the Initiator prior to disconnection from 
the SCSI bus. This command also supports linked SCSI 
operations by optionally allowing a linked command- 
complete message to be sent after the status is trans- 
ferred. Linked command complete messages are 
controlled by the CDB12 register with bits that corre- 
spond to the standard linked command control bits in 
the CDB. 

Before a Send-Status-And-Command-Complete com- 
mand is issued, the CDB11 register must be loaded with 
a status byte which will then be transferred across the 
SCSI bus. Also, the link control bits from the current 
CDB must be loaded into the CDB12 register to ensure 
that the correct sequence occurs. Note that the bits 
used by the WD33C93A are identical in meaning to the 
SCSI standard link control bits. The host processor may 
simply load the control byte from the current SCSI 
command into CDB12 to get the correct function. As the 
command execution progresses, the Command Phase 
register will be updated to indicate the last phase 
completed. 

The possible sequences caused by this command are 
as follows: 

(1) CDB12 bitO = 0, bitl = don’t care: The status byte in 


CDB11 is sent, followed by a Command Complete 
message (00 Hex). A “successful completion” inter- 
rup now occurs. 

(2) CDB12 bitO = 1 , bitl = 0: The status byte in CDB11 is 
sent, followed by a Linked Command Complete 
message (OA Hex). A chain to the command fetch 
portion of Wait-for-Select-and-Receive then occurs 
to fetch the next CDB from the Initiator. WD33C93A 
command execution proceeds as described for that 
command. 

(3) CDB12 bitO = 1 , bitl = 1 : The status byte in CDB11 is 
sent, followed by a Linked Command Complete with 
Flag message (OB Hex). A chain to the command 
fetch portion of Wait-for-Select-and-Receive then 
occurs to fetch the next CDB from the Initiator. 
WD33C93A command execution proceeds as 
described for that command. 

A Send-Status-And-Command-Complete command 
may be terminated by ATN- asserted when HA = 1, or 
when a Disconnect or Reset command is issued. In 
addition, it may be aborted on a SCSI bus-phase 
boundary by issuing an Abort command. 

The following table summarizes the possible values 
that the Command Phase register can take during the 
Send-Status-and-Command-Complete command, and 
their meanings relative to command termination. See 
other command descriptions for additional values that 
can occur when command chaining is used. 


COMMAND 

PHASE 

MEANING 

00 

No operation occurred; typically, ATN- was found to be asserted. 

50 

Status phase transfer completed. 

60 

Command Complete message transfer completed. 

61 

Linked Command Complete message transfer completed. 


A “Resume Send-Status-And-Command-Complete” 
command is assumed wheneve a normal “Send-Sta- 
tus-And-Command-Complete” command is issued 
while the WD33C93A is in the Connected as a Target 
state. When the “Resume” is issued, the WD33C93A 
examines the Command Phase Register to determine 
where to restart the Send-Status-And-Command-Com- 


plete command execution. This feature, in 
conjunction with the capability to chain to other com- 
bination commands, allows longer SCSI bus 
sequences to be executed by a single command. 

The following table briefly describes the meaning of the 
Command Phase register when resuming a Send-Sta- 
tus-And-Command-Complete command: 


COMMAND 

PHASE 

MEANING 

50 

Resume after status phase. Start with command complete message. May chain to 
command fetch if commanded to do so. 
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7.6.5 SEND-DISCONNECT-MESSAGE 
(OE HEX) 

The Send-Disconnect-Message command is a Target- 
role command which may be used to disconnect from 
the SCSI bus at any time during a SCSI command 
sequence. This command consists of sending a Discon- 
nect message byte, followed by physical disconnection 
from the bus (SCSI bus free). An interrupt is generated 
only after transition to bus free occurs. As an option, a 
Save Data Pointers message will automatically be sent 
before the Disconnect message whenever the IDI bit is 
set prior to issuing this command. 

The Command Phase register is updated during execu- 
tion of the Send-Disconnect-Message command to 
indicate bus phase status. After a Save Data Pointers 


message is sent, the Command Phase will be set to 
41 H. After the Disconnect message transfer, this regis- 
ter will be updated to 42H, and after disconnection the 
Command Phase register will contain a 43H. 

A Send-Disconnect-Message command may be termi- 
nated by ATN- asserted when HA = 1 , or when a Discon- 
nect or Reset command is issued. In addition, it may be 
aborted on a SCSI bus-phase boundary by issuing an 
Abort command. 

The following table summarizes the possible values 
that the Command Phase Register can take during the 
Send-Disconnect-Message, and their meanings rela- 
tive to command termination. See other command 
descriptions for additional values that can occur when 
command chaining is used. 


COMMAND 

PHASE 

MEANING 

00 

No operation occurred; typically, ATN- was found to be asserted. • 

41 

The Save Data Pointer message was transferred. 

42 

The Disconnect message was transferred. 

43 

The bus free state occurred after the Disconnect message was transferred. The 
WD33C93A is now in the disconnected state. 


8. ELECTRICAL CHARACTERISTICS 
ABSOLUTE MAXIMUM RATINGS 

Voltage on any pin with respect to GND 

Operating temperature 

Storage temperature 

Power dissipation 

Input Static Discharge Protection 

DC OPERATING CHARACTERISTICS 

Ta = 0 to 70 deg. C 

VCC = +5V + /- .25V, GND = 0V 


-0.5V to + 7.0V 
0 to 70 degrees C 
-55 to + 125 degrees C 
500 mW 

1200 V pin to pin 


SYMBOL 

CHARACTERISTICS 

MIN 

MAX 

UNITS 

CONDITIONS 

ML 

INPUT LEAKAGE 


10 

uA 

VIN = .4 TO VCC 

IOL1 

SCSI OUTPUT LEAKAGE 
(INACTIVE) 


50 

uA 

VOUT = .5 TO 

VCC 

IOL2 

OUTPUT LEAKAGE 
(TRI-STATE) 


10 

uA 

VOUT = .4 TO 

VCC 

VIH 

INPUT HIGH VOLTAGE 

2.0 


V 


VIL 

INPUT LOW VOLTAGE 


0.8 

V 


VIHYS 

SCHMITT TRIGGER INPUT 
HYSTERISIS (ALL SCSI PINS) 

0.2 


V 


VOH 

OUTPUT HIGH VOLTAGE 

2.4 


V 

IO = -400 uA 

VOL1 

SCSI OUTPUT LOW VOLTAGE 


0.5 

V 

IO = 48.0 mA 

VOL2 

OUTPUT LOW VOLTAGE 
(ALL OTHERS) 


0.4 

V 

IO = 4.0 mA 

ICC 

SUPPLY CURRENT 


20 

mA 

Ta = +25 deg. C 
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9. TIMING CHARACTERISTICS 

Timing characteristics are valid over the entire operat- 
ing temperature (0 to 70 deg. C) and voltage (4.75 to 
5.25 Volts) ranges, and are referenced to and from a low 
voltage of 0.8 volts and a high voltage of 2.0 volts. All 
outputs are assumed to have a load capacitance of 50 
picofarads. 

Many of the SCSI bus timing parameters that follow are 
defined in terms of an internal clock cycle time that is 
determined by the input clock and the clock divisor 
selected in the OWN ID register. This cycle time is 
calculated as follows: 


Tcyc 


Ticlk * DIVISOR 
2 


Where: 

Tcyc is the internal clock cycle time; 

Ticlk is the period of the clock at the MCK input; 
DIVISOR is the clock divisor selected in the OWN ID 
register. 

For example, with a 16MHz clock input to the 
WD33C93A, the clock divisor selected would be 4. 
Therefore, the value of Tcyc would be: 



9.1 PROCESSOR/DMA INTERFACE 

9.1.1 CLK 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tcp 

CLOCK PERIOD 

62.5 

125 

ns 

tch 

CLOCK HIGH 

28 


ns 

to. 

CLOCK LOW 

28 


ns 




33 
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9.1.3 PROCESSOR WRITE - INDIRECT ADDRESSING MODE 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tavwl 

ADDR VALID TO WE LOW 

0 


ns 

tclwl 

CS LOW TO WE LOW 

0 


ns 

twe 

WE PULSE WIDTH 

120 


ns 

^dvwh 

DATA VALID TO WE HIGH 

70 


ns 

^whai 

WE HIGH TO ADDR. INVALID 

0 


ns 

^whch 

WEHIGH TOCS HIGH 

0 


ns 

^whdi 

WE HIGH TO DATA INVALID 

0 


ns 

^whwl 

WE HIGH TO WE OR RE LOW 

100 


ns 



D0-D7 
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9.1.4 PROCESSOR READ - INDIRECT ADDRESSING MODE 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

^avrl 

ADDR VALID TO RE LOW 

0 


ns 

tclrl 

CS LOW TO RE LOW 

0 


ns 

tre 

RE LOW TO DATA VALID 

180 

10000 

ns 

Lldv 

RE PULSE WIDTH LOW TO DATA VALID 

180 

180 

ns 

trhch 

RE HIGH TOCS HIGH 

0 


ns 

Lhdi 

RE HIGH TO DATA INVALID 

10 

40 

ns 

Lhrl 

RE HIGH TO RE OR WE LOW 

100 


ns 

^rhai 

RE HIGH TO AO INVALID 

0 


ns 
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9.1.6 PROCESSOR READ - DIRECT ADDRESSING MODE 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

taval 

ADDR VALID TO ALE LOW 

40 


ns 

talai 

ALE LOW TO ADDR INVALID 

0 


ns 

^alrl 

ALE LOW TO RE LOW 

30 


ns 

Wl 

CS LOW TO RE LOW 

0 


ns 

tre 

RE PULSE WIDTH 

180 

10000 ns 


^rldv 

RE LOW TO DATA VALID 


180 

ns 

Vhch 

RE HIGH TO CS HIGH 

0 


ns 

^rhdi 

RE HIGH TO DATA INVALID 

10 

40 

ns 

Wl 

RE HIGH TO RE OR WE LOW 

100 


ns 
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9.1.8 DMA READ 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tdlrl 

DACK LOW TO RE LOW 

0 


ns 

tdlqh 

DACK, RE LOW TO DRQ HIGH 

40 

90 

ns 

trd 

RE PULSE WIDTH 

80 


ns 

trhrl 

RE HIGH TO RE LOW 

100 


ns 

Vldv 

RE LOW TO DATA VALID 


70 

ns 

Lhdh 

RE HIGH TO DACK HIGH 

0 


ns 

trhdi 

RE HIGH TO DATA INVALID 

5 

40 

ns 

trhdl 

DRQ HIGH TO DRQ LOW 

100 


ns 

^dhql 

DACK HIGH TO DRQ LOW 

30 


ns 



NOTE: External load on DRQ & DACK is assumed to be 1KO. 
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9.1.9 WD-BUS BUFFER WRITE 

SYMBOL 

CHARACTERISTIC 

tqhsl 

DRQ HIGH TO RCS LOW 

tslwv 

RCS LOW TO WE VALID 

two 

WE PULSE WIDTH 

Lvldv 

WE LOW TO DATA VALID 

twhdi 

WE HIGH TO WE LOW 

twhwl 

We high to We low 

tqlsh 

DRQ LOW TO RCS HIGH 

t h 

RCS HIGH TO WE INVALID 


DRQ (IN) 


RCS (OUT) 


WE (OUT) 



twHDI^j 
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9.1.10 WD-BUS BUFFER READ 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tqhsl 

DRQ HIGH TO RCS LOW 

0 


ns 

^slrv 

RCS LOW TO RE VALID 

0 

20 

ns 

Lo 

RE PULSE WIDTH 

Tcyc-20 


ns 

Ljvrh 

DATA VALID TO RE HIGH 

10 


ns 

Lhdi 

RE HIGH TO DATA INVALID 

10 


ns 

Lhrl 

RE HIGH TO RE LOW 

TCYC-20 


ns 

tqlsh 

DRQ LOW TO RCS HIGH 

8*Tcyc 

10*Tcyc 

ns 

tshri 

RCS HIGH TO RE INVALID 

0 

100 

ns 



225 
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9.1.11 BURST DMA WRITE 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 


tdlwl 

DACK LOW TO WE LOW 

0 


ns 

L/lqh 

WE LOW TO DRQ HIGH 


75 

ns 

Lvr 

We pulse width 

50 


ns 

Lvhwl 

WE HIGH TO WE LOW 

80 


ns 

Livwh 

DATA VALID TO WE HIGH 

25 


ns 

Lvhdh 

WE HIGH TO DACK HIGH 

0 


ns 

L/hdi 

WE HIGH TO DATA INVALID 

0 


ns 
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9.1.12 BURST DMA READ 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

Wi 

DACK LOW TO RE LOW 

0 


ns 

Llqh 

RE LOW TO DRQ HIGH 


75 

ns 

trd 

RE PULSE WIDTH 

80 


ns 

Lhrl 

RE HIGH TO RE LOW 

80 


ns 

^rldv 

RE LOW TO DATA VALID 


50 

ns 

Lhdh 

RE HIGH TO DACK HIGH 

0 


ns 

Lhdi 

RE HIGH TO DATA INVALID 

5 

40 

ns 


DRQ (OUT) 


DACK (IN) 
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9.2 SCSI INTERFACE 
9.2.1 ARBITRATION 



Igroup 

Tgroup 


NOTE: Tgroup = signals driven by a Target = I/ O, C/D, MS G, REQ 
Igroup = signals driven by an Initiator = ATN, ACK 
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9.2.2 SELECTING A TARGET (AS AN INITIATOR) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tsloo 

SEL OUT LOW TO “OR-ED” ID OUT 

1.2 


us 

tovao 

“OR-ED” ID OUT VALID TO ACK, ATN OUT 

100 


ns 

^aobh 

ACK, ATN OUT VALID TO BSY OUT HIGH 

100 


ns 

tbhbv 

BSY OUT HIGH TO BSY IN LOW VALID 

400 


ns 

Wh 

BSY IN LOW TO SEL OUT HIGH 

100 


ns 


BSY 


SEL 


DBx 


ATN 


ACK 



Tgroup 

NOTE: Tgroup = signals driven by a Target = FO, C/D, MSG, REQ 
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9.2.3 RESPONSE TO SELECTION (AS A TARGET) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

*slbh 

SEL IN LOW TO BSY IN HIGH 

0 


ns 

^ivbh 

“OR-ED” ID VALID IN TO BSY IN HIGH 

0 


ns 

tbhbl 

SEL LOW, ID VALID, BSY HIGH TO BSY LOW 

0.4 

200 

us 

^bloi 

BSY OUT LOW TO “OR-ED” ID INVALID IN 

0 


ns 

tblsh 

BSY OUT LOW TO SEL IN HIGH 

0 


ns 

^avsh 

ATN VALID IN TO SEL IN HIGH 

0 


ns 

tshio 

SEL IN HIGH TO Tgroup OUT 

100 


ns 


BSY 


SEL 


DBx 


ATN 


ACK 


Tgroup 



NOTE: Tgroup = signals driven by a Target = I/O, C/D, MSG, REQ 
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9.2.4 RESELECTING AN INITIATOR (AS A TARGET) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tsloo 

SEL OUT LOW TO “OR-ED” ID OUT 

1.2 


us 

^ovio 

“OR-ED” ID VALID TO I/O and Tgroup OUT 

VALID 

100 


ns 

tiobh 

I/O and Tgroup OUT VALID TO BSY OUT HIGH 

100 


us 

tbhbv 

BSY OUT HIGH TO BSY IN LOW VALID 

400 


ns 

tblsh 

BSY IN LOW TO SEL OUT HIGH 

100 


ns 


BSY 

SEL 





♦ 



N 

— 
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9.2.5 RESPONSE TO RESELECTION (AS AN INITIATOR) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

Ulbh 

SEL IN LOW TO BSY IN HIGH 

0 


ns 

tivbh 

“OR-ED” ID VALID IN TO BSY IN HIGH 

0 


ns 

tilbh 

170 IN LOW TO BSY IN HIGH 

0 


ns 

tbhao 

SEL LOW, ID VALID, BSY HIGH TO Igroup OUT 

100 


ns 

^avbl 

Igroup VALID OUT TO BSY OUT LOW 

100 


ns 

tbhbl 

BSY IN HIGH TO BSY OUT LOW 

0.4 

200 

us 

^bloi 

BSY OUT LOW TO “OR-ED” INVALID IN 

0 


ns 

*blsh 

BSY OUT LOW TO SEL IN HIGH 

0 


ns 

tshbh 

SEL IN HIGH TO BSY OUT HIGH 

0 


ns 



Tgroup 

NOTE: Tgroup = signals driven by a Target = C /D, MSG, R EQ 
Igroup = signals driven by an Initiator = ATN, ACK 

' “ BSY will still be driven low by the reselecting target. 
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9.2.6 RECEIVE ASYNCHRONOUS INFORMATION TRANSFER IN (ACTING AS AN INITIATOR) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tshpc 

SEL IN HIGH TO PHASE CHANGE IN 

0 


ns 

tildt 

TTO IN LOW TO DATA BUS TRISTATE 

0 

125 

ns 

fpcrl 

PHASE CHANGE IN TO REQ IN LOW 

400 


ns 

tdvrl 

DATA VALID IN TO REQ IN LOW 

0 


ns 

trial 

REQ IN LOW TO ACK OUT LOW 

0 

175 

ns 

taldi 

ACK OUT LOW TO DATA INVALID IN 

0 


ns 

talrh 

ACK OUT LOW TO REQ IN HIGH 

0 


ns 

trhah 

REQ IN HIGH TO ACK OUT HIGH 

0 

175 

ns 

tahpc 

ACK OUT HIGH TO PHASE CHANGE IN 

0 


ns 



ATN 

NOTE: Phase = signals that define the bus phase C/D, MSG 
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9.2.7 SEND ASYNCHRONOUS INFORMATION TRANSFER IN (ACTING AS A TARGET) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tshpc 

SEL IN HIGH TO PHASE CHANGE OUT 

100 


ns 

Lido 

170 OUT LOW TO DATA OUT 

800 


ns 

Llvrl 

DATA OUT VALID TO REQ OUT LOW 

55 


ns 

tpcrl 

PHASE CHANGE OUT TO REQ OUT LOW 

500 


ns 

trial 

REQ OUT LOW TO ACK IN LOW 

0 


ns 

talrh 

ACK IN LOW TO REQ OUT HIGH 

0 

175 

ns 

trhdi 

REQ OUT HIGH TO DATA OUT INVALID 

0 


ns 

trhah 

REQ OUT HIGH TO ACK IN HIGH 

0 


ns 

tahpc 

ACK IN HIGH TO PHASE CHANGE OUT 

100 


ns 

tahrl 

ACK IN HIGH TO REQ OUT LOW 

0 

175 

ns 



NOTE: Phase = signals that define the bus phase C/D, MSG 
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9.2.8 SEND ASYNCHRONOUS INFORMATION TRANSFER OUT (ACTING AS AN INITIATOR) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tshpc 

SEL IN HIGH TO PHASE CHANGE IN 

0 


ns 

tjhdo 

iTO IN HIGH TO DATA OUT 

0 


ns 

tpcrl 

PHASE CHANGE IN TO REQ IN LOW 

400 


ns 

^rlal 

REQ IN LOW TO ACK OUT LOW 

0 

175 

ns 

tdval 

DATA OUT VALID TO ACK OUT LOW 

55 


ns 

talrh 

ACK OUT LOW TO REQ IN HIGH 

0 


ns 

trhah 

REQ IN HIGH TO ACK OUT HIGH 

0 

175 

ns 

tahdi 

ACK OUT HIGH TO DATA OUT INVALID 

o 


ns 

tahpc 

ACK OUT HIGH TO PHASE CHANGE IN 

0 


ns 
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9.2.9 RECEIVE ASYNCHRONOUS INFORMATION TRANSFER OUT (ACTING AS AN TARGET) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tshpc 

SEL IN HIGH TO PHASE CHANGE OUT 

100 


ns 

fihdt 

]70 OUT HIGH TO DATA BUS TRISTATE 


0 

ns 

tpcrl 

PHASE CHANGE TO REQ OUT LOW 

500 


ns 

trial 

REQ OUT LOW TO ACK IN LOW 

0 


ns 

Wal 

DATA IN VALID TO ACK IN LOW 

5 


ns 

falrh 

ACK IN LOW TO REQ OUT HIGH 

0 

175 

ns 

trhdi 

REQ OUT HIGH TO DATA IN INVALID 

0 


ns 

Vhah 

REQ OUT HIGH TO ACK IN HIGH 

0 


ns 

fahpc 

ACK IN HIGH TO PHASE CHANGE OUT 

0 


ns 

fahrl 

ACK IN HIGH TO REQ OUT LOW 

0 

175 

ns 



NOTE: Phase = signals that define the bus phase C/D, MSG 
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9.2.10 RECEIVE SYNCHRONOUS INFORMATION TRANSFER IN (ACTING AS AN INITIATOR) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tdvrl 

DATA VALID IN TO REQ IN LOW 

0 


ns 

trldi 

REQ IN LOW TO DATA INVALID 

45 


ns 

Wh 

REQ IN LOW TO REQ IN HIGH 

50 


ns 

trhrl 

REQ IN HIGH TO REQ IN LOW 

50 


ns 

talah 

ACK OUT LOW TO ACK OUT HIGH 

Tcyc-10 


ns 

tahal 

ACK OUT HIGH TO ACK OUT LOW 

Tcyc-25 


ns 

^ahpc 

ACK OUT HIGH TO PHASE CHANGE 

0 


ns 


PARAMETERS tshpc, tildt, and tpcrl ARE ALSO APPLICABLE AND ARE IDENTICAL TO THOSE IN 9.2.6. 



NOTE: Phase = signals that define the bus phase C/D, MSG 
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9.2.11 SEND SYNCHRONOUS INFORMATION TRANSFER IN (ACTING AS A TARGET) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

fdvrl 

DATA VALID OUT TO REQ OUT LOW 

55 


ns 

Lldi 

REQ OUT LOW TO DATA INVALID OUT 

100 


ns 

frlrh 

REQ OUT LOW TO REQ OUT HIGH 

Tcyc-10 


ns 

frhrl 

REQ OUT HIGH TO REQ OUT LOW 

Tcyc-25 


ns 

falah 

ACK IN LOW TO ACK IN HIGH 

50 


ns 

fahal 

ACK IN HIGH TO ACK IN LOW 

50 


ns 

tahpc 

ACK IN HIGH TO PHASE CHANGE OUT 

0 


ns 


PARAMETERS tshpc, tildt, and tpcrl ARE ALSO APPLICABLE AND ARE IDENTICAL TO THOSE IN 
SUBSECTION 9.2.7. 


DBx — Y 


1 / 0 - 




Wdi 


X 




Phase 


REQ- 


ACK- 


ATN- 


^RHRL 




X 




NOTE: Phase = signals that define the bus phase C/D, MSG 
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9.2.12 SEND SYNCHRONOUS INFORMATION TRANSFER OUT (ACTING AS AN INITIATOR) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

Wal 

DATA VALID OUT TO ACK OUT LOW 

55 


ns 

taldi 

ACK OUT LOW TO DATA INVALID OUT 

100 


ns 

Wh 

REQ IN LOW TO REQ IN HIGH 

50 


ns 

Lhrl 

REQ IN HIGH TO REQ IN LOW 

50 


ns 

talah 

ACK OUT LOW TO ACK OUT HIGH 

Tcyc-10 


ns 

tahal 

ACK OUT HIGH TO ACK OUT LOW 

Tcyc-25 


ns 

tahpc 

ACK OUT HIGH TO PHASE CHANGE 

0 


ns 


PARAMETERS tshpc, tildt, and tpcrl ARE ALSO APPLICABLE AND ARE IDENTICAL TO THOSE IN 9.2.8. 




29 


NOTE: Phase = signals that define the bus phase C/D, MSG 


9.2.13 RECEIVE SYNCHRONOUS INFORMATION TRANSFER OUT (ACTING AS A TARGET) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tdval 

DATA VALID IN TO ACK IN LOW 

0 


ns 

taldi 

ACK IN LOW TO DATA INVALID 

45 


ns 

Wh 

REQ OUT LOW TO REQ OUT HIGH 

Tcyc-10 


ns 

Wl 

REQ OUT HIGH TO REQ OUT LOW 

Tcyc-25 


ns 

fatah 

ACK IN LOW TO ACK IN HIGH 

50 


ns 

tahal 

ACK IN HIGH TO ACK IN LOW 

50 


ns 

tahpc 

ACK IN HIGH TO PHASE CHANGE OUT 

0 


ns 


PARAMETERS t shpc , t Ild „ and t pcr , ARE ALSO APPLICABLE AND ARE IDENTICAL TO THOSE IN SUBSECTION 
9.2.9. 
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9.2.14 ARBITRATION TO BUS FREE 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tslbh 

SEL IN LOW TO BSY HIGH, DATA TRI-STATE 


o 

£|8 

CO + 

ns 



9.2.15 SELECTION (AS AN INITIATOR) OR RESELECTION (AS A TARGET) TO BUS FREE 
(SELECTION TIMEOUT) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

ttadc 

TIMEOUT OR ABORT TO DATA BUS CLEARED 

0 


ns 

Wsh 

DATA BUS CLEARED TO ME OUT HIGH 

200 


us 

^shdt 

SEL OUT HIGH TO DATA BUS TRISTATE 


800 

ns 

tshih 

Ml OUT HIGH TO cntl TRISTATE 


800 

ns 


BSY - 


S 



NOTE: Tgroup = signals driven by a Target = I/ O, C/D, MS G, REQ 
Igroup = signals driven by an Initiator = ATN, ACK 
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9.2.16 CONNECTED-AS-AN-INITIATOR TO BUS FREE 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

^bhdt 

BSY IN HIGH TO DATA BUS TRISTATE 


8*Tcyc 
+ 75ns 

ns 

tbhgt 

BSY IN HIGH TO Igroup TRISTATE 


8*Tcyc 
+ 75ns 

ns 



29 


NOTE: Igroup = signals driven by an Initiator = ATN, ACK 


9.2.17 CONNECTED-AS-A-TARGET TO BUS FREE 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 


tbhdt 

BSY OUT HIGH TO DATA BUS TRISTATE 

8*Tcyc 
+ 75ns 

ns 


^bhgt 

BSY OUT HIGH TO Tgroup TRISTATE 

! 


8*Tcyc 
+ 75ns 

ns 



NOTE: Tgroup = signals driven by a Target = I/O, C/D, MSG, REQ 
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PACKAGE DIAGRAMS 



40 LEAD PLASTIC “PL” 
WD33C93A 



44 LEAD PLASTIC “JM” 
WD33C93A 
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